Portál AbcLinuxu, 19. dubna 2024 08:41


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

22.6.2007 17:41 Thunder.m | skóre: 35 | blog: e17
MYSQL - order podle jména v UTF-8
Přečteno: 2097×
Odpovědět | Admin
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:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

22.6.2007 18:08 razor | skóre: 33
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
Odpovědět | | Sbalit | Link | Blokovat | Admin
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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.
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: 33
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: 33
Rozbalit Rozbalit vše Re: MYSQL - order podle jména v UTF-8
mam totiž podezření že ty data nebudou v utf8
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)
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 :(
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)
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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, (c) 1999-2007 Stickfish s.r.o.