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

    Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.

    Ladislav Hagara | Komentářů: 0
    včera 21:11 | IT novinky

    Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.

    Ladislav Hagara | Komentářů: 0
    včera 17:55 | Nová verze

    AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | IT novinky

    Před 50 lety, 5. května 1974 v žurnálu IEEE Transactions on Communications, Vint Cerf a Bob Kahn popsali protokol TCP (pdf).

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | Zajímavý článek

    Bylo vydáno do češtiny přeložené číslo 717 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.

    Ladislav Hagara | Komentářů: 0
    včera 04:00 | Nová verze

    Byla vydána (Mastodon, 𝕏) nová stabilní verze 2.10.38 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP je již k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 5
    včera 00:22 | Komunita

    Google zveřejnil seznam 1220 projektů od 195 organizací (Debian, GNU, openSUSE, Linux Foundation, Haiku, Python, …) přijatých do letošního, již dvacátého, Google Summer of Code.

    Ladislav Hagara | Komentářů: 2
    5.5. 22:22 | IT novinky

    Na základě DMCA požadavku bylo na konci dubna z GitHubu odstraněno 8535 repozitářů se zdrojovými kódy open source emulátoru přenosné herní konzole Nintendo Switch yuzu.

    Ladislav Hagara | Komentářů: 7
    5.5. 00:33 | Nová verze

    Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.1.0. Po devíti letech od vydání předchozí verze 3.0.5. Doména dillo.org již nepatří vývojářům Dilla.

    Ladislav Hagara | Komentářů: 0
    4.5. 15:00 | Komunita

    O víkendu probíhá v Bostonu, a také virtuálně, konference LibrePlanet 2024 organizovaná nadací Free Software Foundation (FSF).

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (8%)
     (15%)
     (14%)
    Celkem 118 hlasů
     Komentářů: 8, poslední 4.5. 08:25
    Rozcestník

    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: 2099×
    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: 33
    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.
    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
    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.