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í
×
dnes 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
včera 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 4
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 10
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
20.1. 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 362 hlasů
 Komentářů: 25, poslední včera 13:34
Rozcestník
Reklama

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: 578×
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.