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 20:22 | IT novinky

    Linux Foundation Europe představila projekt RISE (RISC-V Software Ecosystem), jehož cílem je urychlit vývoj open source softwaru pro architekturu RISC-V.

    Ladislav Hagara | Komentářů: 0
    dnes 14:55 | Nová verze

    Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu pro jednodeskové počítače na platformě ARM, byl vydán ve verzi 23.05. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 0
    dnes 12:33 | Komunita

    Minulý týden proběhla openSUSE Conference 2023. Mimo jiné bylo oznámeno přejmenování systému MicroOS Desktop. MicroOS Desktop GNOME byl přejmenován na openSUSE Aeon a MicroOS Desktop Plasma na openSUSE Kalpa.

    Ladislav Hagara | Komentářů: 0
    dnes 09:00 | Komunita

    Thom Holwerda z OSnews si všímá, že vývoj operačního systému MINIX je prakticky mrtvý. Jeho hlavní autor, Andrew Tanenbaum, formálně odešel do důchodu v roce 2014 a příspěvky do kódu v následujících letech vůbec ustaly. Stav projektu shrnuje diskuze z roku 2020. Sice vyšlo najevo, že Intel používal MINIX v Management Engine, ale změny nezveřejňoval.

    Fluttershy, yay! | Komentářů: 0
    dnes 07:00 | Nová verze

    Google Chrome 114 byl prohlášen za stabilní. Nejnovější stabilní verze 114.0.5735.90 přináší řadu oprav a vylepšení (YouTube). Vypíchnut je CHIPS (Cookies Having Independent Partitioned State). Opraveno bylo 16 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Komunita

    Byly zveřejněny prezentace a videozáznamy přednášek a fotografie z česko-slovenského setkání poskytovatelů přístupu k internetu, provozovatelů telekomunikačních sítí, registrátorů domén a provozovatelů počítačových sítí a technických nadšenců CSNOG 2023 (Czech and Slovak Network Operators Group) konaného 16. a 17. května ve Zlínu.

    Ladislav Hagara | Komentářů: 0
    včera 17:00 | Pozvánky

    Soutěž amatérských robotů Robotický den 2023 proběhne v neděli 4. června v Kongresovém centru Praha.

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

    V Tchaj-peji probíhá počítačový veletrh COMPUTEX 2023. Firmy představují své novinky. Nvidia například superpočítač DGX GH200 AI.

    Ladislav Hagara | Komentářů: 2
    včera 12:11 | Nová verze

    Vyšla nová verze XMPP (Jabber) klienta Gajim. Nejvýznamnější novinkou je integrace OMEMO pluginu přímo do jádra aplikace, takže již není třeba plugin samostatně instalovat. Přehled dalších novinek je dostupný na oficiálních stránkách. Gajim je vytvořen v jazyce Python s využitím knihovny GTK a vedle Linuxu jej lze vyzkoušet i na platformách MacOS a Windows.

    sonicpp | Komentářů: 0
    29.5. 22:22 | Komunita

    Komunita KDE představila stránku KDE for Developers pro vývojáře používající KDE aplikace. Postupně byly představeny stránky pro umělce KDE for Creators, děti KDE for Kids a vědce KDE for Scientists.

    Ladislav Hagara | Komentářů: 8
    Obnovovací frekvenci obrazovky (LCD) preferuji
     (74%)
     (20%)
     (4%)
     (2%)
    Celkem 833 hlasů
     Komentářů: 13, poslední 25.5. 07: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: 2082×
    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.