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 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
včera 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
21.1. 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
21.1. 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 363 hlasů
 Komentářů: 25, poslední 21.1. 13:34
Rozcestník
Reklama

Dotaz: MYSQL - order podle jména v UTF-8

Thunder.m avatar 22.6.2007 17:41 Thunder.m | skóre: 35 | blog: e17
MYSQL - order podle jména v UTF-8
Přečteno: 2061×
Potřeboval bych načítat data seřazená podle jména, jména jsou však v UTF-8 a používají češtinu (čď atd...) a ještě k tomu jsou občas malými a občas velkými písmeny. Chtěl bych tedy seřadit data podle jména včetně správné češtiny a bez rozdílu velké/malé písmeno, nevíte jak to udělat?

Používám "order by name", ale to mi řadí například Ž, nebo Č na začátek, což je blbě.

Řešení dotazu:


Odpovědi

22.6.2007 18:08 razor | skóre: 32
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
zdar, k tomu se používá klausule collate např: order by x collate utf8_czech_ci
Jan Zahornadsky avatar 22.6.2007 18:08 Jan Zahornadsky | skóre: 22 | blog: hans_blog
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
Použij COLLATE. Samozřejmě je ale lepší tu tabulku (resp. databázi) vytvořit s nějakým výchozím COLLATION na sloupci, aby se to nemuselo vkládat do každého dotazu (a mj. vznikl obrovský problémový potenciál).
Actually, I was half an hour into the pointer scripting documentation when she got dressed and left.
Thunder.m avatar 22.6.2007 18:33 Thunder.m | skóre: 35 | blog: e17
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
Diky moc všem co mi poradili, ale jsem z toho stále jelen, pořád mi to například slovo Žofínské háže uplně na začátek :(
22.6.2007 18:43 razor | skóre: 32
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
a co vypíše příkaz: show create table tabulka_s_jmeny ?
22.6.2007 18:46 razor | skóre: 32
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
mam totiž podezření že ty data nebudou v utf8
Thunder.m avatar 22.6.2007 18:58 Thunder.m | skóre: 35 | blog: e17
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
No je to možné, protože ač mam v phpmyadmin zaškrtnuté utf8, tak se data zobrazují blbě, používám Joomlu 1.0.22 a v ní čeština jde, web má kódování v utf-8, tak jedině že by nějak vnitřně komunikoval jiným kódováním.
Řešení 1× (Kroko)
Thunder.m avatar 23.6.2007 09:55 Thunder.m | skóre: 35 | blog: e17
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
Hmm, tak je to opravdu tak, databáze i Joomla jsou sice nastaveny na UTF, ale data se opravdu v UTF do databáze neukládala, jakmile jsem povolil řádek
@mysql_query("SET NAMES 'utf8'", $this->_resource);
v database.php, tak se celý web zobrazuje správně, jen jediný záznam, kterým jsem ručně přepsal v phpmyadmin je správně.

Nevíte jak bych mohl celou databázi překódovat? Ani nevím v jakém kódování jsou tam ta data opravdu nahrána :(
Thunder.m avatar 22.6.2007 18:56 Thunder.m | skóre: 35 | blog: e17
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
mysql> show create table jos_datsogallery_catg;
+-----------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table                 | Create Table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
+-----------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| jos_datsogallery_catg | CREATE TABLE `jos_datsogallery_catg` (
  `cid` int(11) NOT NULL auto_increment,
  `name` varchar(255) collate utf8_czech_ci NOT NULL,
  `parent` varchar(255) collate utf8_czech_ci NOT NULL default '0',
  `description` text collate utf8_czech_ci,
  `ordering` int(11) NOT NULL default '0',
  `access` tinyint(3) unsigned NOT NULL default '0',
  `published` char(1) collate utf8_czech_ci NOT NULL default '0',
  PRIMARY KEY  (`cid`)
) ENGINE=MyISAM AUTO_INCREMENT=64 DEFAULT CHARSET=utf8 COLLATE=utf8_czech_ci | 
+-----------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
Řešení 1× (Kroko)
Thunder.m avatar 23.6.2007 11:01 Thunder.m | skóre: 35 | blog: e17
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
Takže problém je "konečně" vyřešen. Pokud by se někdo dostal do podobného problému jako já, tak zde popíšu postup jak se z něj vymotat.

Používám Joomlu verze 1.0.12, ta neumí uplně UTF-8, takže ikdyž je v konfiguraci nastavenou UTF-8 a zároveň je databáze také nastavena na UTF-8, tak Joomla i přesto data ukládá blbě v latin1. Viz tento odkaz ve kterém je to trochu objasněno.

Můj problém se týkal toho, že ač jsem používal řazení podle jména, tak se data obsahující některé speciální znaky (žčš atd..) řadila špatně, bylo to tím že v databázi byla opravdu uložena blbě.

Existují alespoň 2 řešení. První řešení je trochu pracne, ale asi funkčnější, implementovat v php řazení pomocí usort na již získaná dat z databáze. Druhé řešení je nastavit joomlu tak aby s databází opravdu komunikovala v UTF-8 a databázi převést, toto řešení jsem použil já.

Jak tedy na to? Není to žádná hračka, trvalo mi pár hodin, než jsem vygooglil správný postup.

mysqldump -u root -p --default-character-set=latin1 -c --insert-ignore --skip-set-charset dana_databaze > dump.sql
mysql -u root -p --execute="DROP DATABASE dana_databaze;CREATE DATABASE dana_databaze CHARACTER SET utf8 COLLATE utf8_general_ci;"
mysql -u root --max_allowed_packet=16M -p --default-character-set=utf8 dana_databaze < dump.sql
A pak už jen nastavit Joomlu tak aby komunikovala s databází v UTF-8, tj. odkomentovat ten jeden řádek v souboru includes/database.php

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.