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 15:33 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.8.

    Ladislav Hagara | Komentářů: 2
    včera 14:22 | IT novinky

    Herní studio Hangar 13 vydalo novou Mafii. Mafia: Domovina je zasazena do krutého sicilského podsvětí na začátku 20. století. Na ProtonDB je zatím bez záznamu.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | IT novinky

    Operátor O2 má opět problémy. Jako omluvu za pondělní zhoršenou dostupnost služeb dal všem zákazníkům poukaz v hodnotě 300 Kč na nákup telefonu nebo příslušenství.

    Ladislav Hagara | Komentářů: 5
    včera 05:55 | IT novinky

    Společnost OpenAI představila GPT-5 (YouTube).

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

    Byla vydána (𝕏) červencová aktualizace aneb nová verze 1.103 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.103 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    7.8. 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 8
    7.8. 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    7.8. 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    7.8. 12:22 | IT novinky

    Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.

    Ladislav Hagara | Komentářů: 5
    7.8. 04:55 | Nová verze

    Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (47%)
     (20%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (18%)
    Celkem 313 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    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: 2124×
    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.