abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 12
    15.8. 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 7
    15.8. 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    15.8. 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 10
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 28
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (2%)
     (1%)
     (1%)
     (17%)
    Celkem 406 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: mysql triedenie utf8_general_ci + unique index

    5.7.2010 13:33 fraxinus | skóre: 20 | blog: fraxinus
    mysql triedenie utf8_general_ci + unique index
    Přečteno: 660×
    Pouzivam mysql databazu. Vsade pouzivam utf8. Mam tabulku s varchar stlpcom. Nad tymto stlpcom mam unikatny index. Ked pouzijem collate utf_general_ci tak "Pl" a "PL" je pre neho to iste. Tiez napr. "S" a "Š" je pre neho to iste takze tam nemozem insertovať. Ten unikatny index skutocne potrebujem kvoli zachovaniu konzistencie. Použil som teda collate utf_bin. Teraz ale zase nefunguje triedenie takze diakritika je na konci: "Š" je za "Z". Ked explicitne v selekte uvediem že chcem order by collate utf8_general_ci tak zahlasi chybu ze to ned binarnym stlpcom nie je mozne.

    Co s tym? Obavam sa ze riesenie neexistuje.

    Zhrnutie: Potrebujem case-sensitive unikatny index a zaroven korektne triedenie diakritiky.

    Řešení dotazu:


    Odpovědi

    5.7.2010 14:13 chrono
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    Určite tam nemáš nejakú chybu? Vytvoril som tabuľku a v jednom stĺpci som pre zotriedenie použil utf8_bin (a unikátny index) a SELECT * FROM `test` ORDER BY `text` COLLATE utf8_general_ci mi funguje bez problémov.
    5.7.2010 14:52 fraxinus | skóre: 20 | blog: fraxinus
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    mysql> set names utf8;
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> create table foo (bar varchar(5) character set utf8 collate utf8_bin);
    Query OK, 0 rows affected (0.04 sec)
    
    mysql> insert into foo values ("S");
    Query OK, 1 row affected (0.00 sec)
    
    mysql> insert into foo values ("Š");
    Query OK, 1 row affected (0.00 sec)
    
    mysql> insert into foo values ("Z");
    Query OK, 1 row affected (0.00 sec)
    
    mysql> insert into foo values ("Ž");
    Query OK, 1 row affected (0.00 sec)
    
    mysql> select * from foo order by 1 collate utf8_general_ci;
    ERROR 1253 (42000): COLLATION 'utf8_general_ci' is not valid for CHARACTER SET 'binary'
    
    5.7.2010 15:12 chrono
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    Zoraďuješ to podľa čísla (binárnej hodnoty) a tam ti to fungovať nebude. Collate musíš použiť pri stĺpci, pri ktorom to má zmysel (takže ORDER BY `bar` fungovať bude).
    5.7.2010 17:04 fraxinus | skóre: 20 | blog: fraxinus
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    > Zoraďuješ to podľa čísla (binárnej hodnoty) a tam ti to fungovať nebude.

    Myslis to cislo za order by?

    >> select * from foo order by 1
    5.7.2010 17:09 chrono
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    Áno. Zoraďovanie (collate) funguje pri reťazcoch a nie pri číslach (čiže collate nemôžeš použiť na stĺpce typu INT a podobné).

    Ak chceš naozaj zoraďovať podľa nejakého čísla, tak tam to collate nedávaj.
    5.7.2010 17:13 fraxinus | skóre: 20 | blog: fraxinus
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    to nie je tym, to je uplne ina nesuvisiaca chyba. Ak je v selekte COLLATE, neda sa pouzit na identifikaciu stlpca jeho poradie ale len jeho meno!
    Řešení 1× (fraxinus (tazatel))
    5.7.2010 17:11 fraxinus | skóre: 20 | blog: fraxinus
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    No to je ale podraz od mysql. Skutocne toto funguje len ak uvediem nazov stlpca, nie jeho poradie:

    select * from user order by name collate utf8_general_ci -- funguje
    select * from user order by 1 collate utf8_general_ci -- NEFUNGUJE
    select * from user order by name -- funguje
    select * from user order by 1 -- funguje (zotriedi podla prveho stlpca)
    8.7.2010 15:52 Sten
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    „ci“ v „utf_general_ci“ znamená „case insensitive“. Co takhle to nahradit za „utf_general_cs“?
    8.7.2010 16:07 chrono
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    Nie sú všetky porovnávania v MySQL len case insensitive? (teda okrem tých binárnych)
    8.7.2010 16:18 Sten
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    Nejsou
    8.7.2010 16:23 Sten
    Rozbalit Rozbalit vše Re: mysql triedenie utf8_general_ci + unique index
    I když teď koukám, že MySQL nemá „utf8_general_cs“, to je stále pouze ve stádiu návrhu

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.