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 01:55 | Pozvánky

    Korespondenční seminář z programování (KSP) pražského Matfyzu pořádá i letos jarní soustředění pro začátečníky. Zváni jsou všichni středoškoláci a starší základoškoláci, kteří se chtějí naučit programovat, lépe uvažovat o informatických úlohách a poznat nové podobně smýšlející kamarády. Úplným začátečníkům bude určen kurz základů programování a kurz základních algoritmických dovedností, pokročilejším nabídneme různorodé

    … více »
    Vladimir Sklenár | Komentářů: 0
    včera 17:33 | Zajímavý článek

    Joe Brockmeier z Linux Weekly News vyzkoušel různé forky webového prohlížeče Mozilla Firefox: především GNU IceCat, Floorp, LibreWolf a Zen. V článku shrnuje, v čem se liší od výchozí konfigurace Firefoxu, co mají za vlastní funkcionalitu, jak a kým jsou udržované atd.

    Fluttershy, yay! | Komentářů: 6
    15.3. 19:22 | Nová verze

    Byl vydán Debian 12.10, tj. desátá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.3. 18:22 | Nová verze

    Byla vydána nová verze 4.5 svobodného notačního programu MuseScore (Wikipedie). Představení novinek v oznámení v diskusním fóru a také na YouTube.

    Ladislav Hagara | Komentářů: 0
    15.3. 17:00 | Nová verze

    Byla vydána nová verze 8.6.0 správce sbírky fotografií digiKam (Wikipedie). Přehled novinek i s náhledy v oficiálním oznámení (NEWS). Nejnovější digiKam je ke stažení také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.

    Ladislav Hagara | Komentářů: 0
    15.3. 04:44 | Komunita

    O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2025. Na programu je celá řada zajímavých přednášek a workshopů. Vstup je zdarma. Přednášky lze sledovat i online na YouTube.

    Ladislav Hagara | Komentářů: 1
    14.3. 22:11 | Nová verze

    Byla vydána nová verze 2.49.0 distribuovaného systému správy verzí Git. Přispělo 89 vývojářů, z toho 24 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    14.3. 19:00 | IT novinky

    Premiér Petr Fiala (ODS) dnes na síti X vyloučil, že by za jeho vlády mohla začít platit vyhláška, podle níž by poskytovatelé internetového připojení měli uchovávat adresy internetových stránek, na které se lidé připojují.

    Ladislav Hagara | Komentářů: 5
    14.3. 12:33 | Komunita

    Flock 2025, tj. konference pro přispěvatele a příznivce Fedory, proběhne od 5. do 8. června v Praze.

    Ladislav Hagara | Komentářů: 0
    13.3. 17:29 | Komunita

    Zemřel Mark Klein, který dlouhá léta pracoval pro telekomunikační firmu AT&T a proslavil se jako whistleblower, když zveřejnil informace o spolupráci AT&T s agenturou NSA. Cílem spolupráce bylo sledovat veškerou komunikaci občanů za pomocí zařízeních v místnosti 641A. O spolupráci obou subjektů napsal knihu Wiring Up The Big Brother Machine...And Fighting It.

    Max | Komentářů: 0
    Jaké je vaše preferované prostředí?
     (27%)
     (1%)
     (1%)
     (1%)
     (1%)
     (2%)
     (64%)
     (2%)
    Celkem 152 hlasů
     Komentářů: 5, poslední 13.3. 11:45
    Rozcestník

    Povzdech nad "omezeností" MySQL

    29.7.2005 08:11 | Přečteno: 1168× | Počítače

    Nedá mi to abych si nepostěžoval na databázi MySQL a její omezené možnosti.

    Od byvaleho zaměstnance jsem zdědil projekt postavený nad MySQL a zákaznik společně s vedenim si usmyslel, že by nebyla od věci vícejazyčnost, sice decentně okleštěná pouze na jednu měnu, ale i tak by měl zákazník mít možnost prohlédnout si web a katalog produktů ve více jazycích. Model databáze není sice na tuto podmínku uzpůsoben, ale po přidání potřebných sloupců pro každý jazyk se to dá vyřešit poměrně jednoduše a bez nějaké ho šíleného převodu dat. Tabulky vypadají tak, že obsahují sloupce name, text a nově přidané sloupce name_en, text_en, name_de, text_de, name_ru a text_ru. Pro dotazování se jsmech chtěl použít pohledy, které by se provéděly v závislosti na jazykové verzi nad pohledy tabulka_cs, tabulka_en, tabulka_de a tabulka_ru.

    Bohužel říkám chtěl jsem, protože MySQL umí pohledy až od verze 5.0.1 (kterou na webhostingu nejspíš neseženete), zatímco jiné databáze je zvládají už velmi dlouho. Rovněž řádná podpora UTF-8 byla přidána až ve verzi 4.1, která je poměrně nová.

    V zásadě mám dvě možnosti:

    1. Přepsat všechny dotazy tak, aby byly závislé na jazyku a vypsat do nich jako trubka vsechny sloupce.
    2. Přepsat aplikaci tak, aby používala PostgreSQL který umí různé fajnové věci.

    Bohužel to asi vidím na bod č. 1. ačkoliv se mi do toho vůbec nechce a aplikaci nehodlám přepisovat, na to nemám čas. Dosti blogování, vzhůru přepisovat dotazy.

           

    Hodnocení: -

    zatím nehodnoceno
            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    29.7.2005 08:19 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Hmmm
    Až přidáš další jazyky, tak možná zjistíš, že by bylo lepší mít tabulku se sloupci name, jazyk, text a že pohledy na to nepotřebuješ :-).

    Jinak data v utf-8 tam můžeš samozřejmě nacpat v jakékoliv verzi.
    29.7.2005 09:01 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: Hmmm
    Taky mě pobavilo, že si někdo tak stěžuje na omezenost MySQL, když neumí navrhnout jednodchou databázi... Další možnost jsou gettext-like tabulky (id, překlad) pro každý jazyk.

    BTW UTF-8 používám jako znakovou sadu v MySQL 3.23 prakticky odjakživa, akorát se musí MySQL opatchovat Kasprzakovym patchem.
    29.7.2005 14:20 Karel Benák | skóre: 8 | blog: benyho
    Rozbalit Rozbalit vše Re: Hmmm
    Machry machry. Až budeš po někom něco předělávat, pak asi pochopíš moje nářky.

    Pochybuju že by Ti webhostingové firmy vyšli vstříct a záplatovali přesně podle Tvých představ.
    Láska je jako prd, když hodně tlačiš tak z toho bude ...
    Luk avatar 29.7.2005 09:02 Luk | skóre: 47 | blog: Kacířské myšlenky | Kutná Hora
    Rozbalit Rozbalit vše Re: Hmmm
    Při vývoji MySQL byly jiné priority (hlavně výkon).

    Co se týká UTF-8, tak to tam samozřejmě nacpat jde, ale např. řazení nebude fungovat správně.
    Šifrování je absolutní nutnost a pomáhá chránit před nekalými živly
    29.7.2005 09:04 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: Hmmm
    No na tabulku s překlady opravdu nutně potřebuju řazení :-). Jinak viz odpověď Yetiho výše.
    29.7.2005 14:15 Karel Benák | skóre: 8 | blog: benyho
    Rozbalit Rozbalit vše Re: Hmmm

    Pánove nevím jestli jste to pochopili nebo vůbec četli, ale pro natvrdlé ještě jednou.

    Já nejsem tvůrcem toho produktu neřešícího lokalizace a využívajícího MySQL.

    Co mě štve je to, že pohledy jsou v MySQL doplněny až od verze 5.0.1 která je zatím dostupná jako beta. No a do databázového schématu pořádně sahat nemůžu. To mám zakázané, protože tu databázi využívá nějaká windowsí aplikace přes ODBC. Tak mě napadlo použít pohledů pro různé jazykové verze a dotazy by zůstaly skoro stejné, jen misto tabulek by se používaly pohledy. Takhle to budu muset řešit přepisováním názvů sloupců pro různé jazykové verze.

    Láska je jako prd, když hodně tlačiš tak z toho bude ...
    29.7.2005 14:24 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: Hmmm
    Jenže podmínku ,do databázového schématu nemohu zasahovat, zato si do tabulek mohu přidělávat sloupce, jak mě napadne` jsi na začátku neuvedl.
    29.7.2005 08:33 lubo
    Rozbalit Rozbalit vše :-)
    ale ved je vseobecne zname, a MySQL AB sa ani inak netvari, ze cielom ich databazy nie je druhy postgres ci oracle. je potrebne pouzivat nastroje na to na co su urcene...
    29.7.2005 08:59 Karel Benák | skóre: 8 | blog: benyho
    Rozbalit Rozbalit vše Re: :-)
    To je sice hezke ze se ani jinak netvari, ale ja jsem nucen jejich produkt pouzivat a mezi tim moci si vybrat a muset neco pouzivat je sakra rozdil.
    Láska je jako prd, když hodně tlačiš tak z toho bude ...
    29.7.2005 09:03 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: :-)
    Ale MySQL AB není ten, kdo tě nutí, tak si stěžuj u toho, kdo tě nutí :-)
    29.7.2005 13:19 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: :-)
    Přesně tak. Fascinuje mne, kolik lidí používá MySQL na aplikace, pro které se absolutně nehodí (protože když ji používají všichni, tak přeci musí být nejlepší) a pak vymýšlejí všelijaké krkolomnosti, kterými se její nedostatky snaží obcházet místo toho, aby použili databázový engine, který disponuje obvyklými funkcemi.
    29.7.2005 13:24 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: :-)
    Obcházení nedostatků MySQL je nepochybně právě tento případ. Pche. Jestli normální postgrčkaři navrhují uložení jazykových variant do databáze takhle, brr...
    29.7.2005 14:03 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: :-)
    Mě spíš fascinuje jak někteří navrhnou blbě databázi a pak si stěžují že databázový engine je blbý…
    29.7.2005 18:29 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: :-)
    Tato databáze je navržena blbě, to je evidentní. Nicméně stejně evidentní je, že MySQL je blbý databázový engine - alespoň pokud se snaží tvářit jako skutečný SQL server.
    29.7.2005 19:53 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: :-)
    Jde o to, čemu říkáš skutečný SQL server :-). Nikdo netvrdí, že implementuje kompletní ANSI SQL 99. Ale je fakt, že na dost využití ta podmnožina funkcí, kterou implementuje, stačí.
    29.7.2005 20:06 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
    Rozbalit Rozbalit vše Re: :-)
    Nebo to spíš blbě čteš. ,,Nicméně stejně evidentní je, že MySQL je blbý databázový engine`` = ,,Používám něco jiného`` :-)
    Copak toho není dost?
    30.7.2005 21:21 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: :-)
    Implikace zleva doprava platí určitě. Ale zprava doleva ani omylem. Například Sybase, DB/2 nebo Oracle také běžně nepoužívám, ale nijak bych se tomu nebránil, pokud by to bylo pro nějaký projekt potřeba. A rozhodně bych o žádném ze jmenovaných neřekl, že je to blbý databázový engine. Dokonce i s MS SQL jsem se celkem snadno srovnal, když jsem byl k tomu dotlačen okolnostmi. Ale kdyby mne někdo nutil stavět jakoukoli netriviální databázovou aplikaci nad MySQL, naprosto jednoznačně bych se odmítl na takovém projektu podílet.
    30.7.2005 21:30 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: :-)
    Ale jistě, pokud se omezíme na schéma "uložím data / přečtu data", na to MySQL pochopitelně stačí velmi dobře, mnohdy i lépe než ty skutečné SQL servery. Jenže pokud chci, aby toho databáze uměla trochu víc, třeba jen prosté udržení konzistence dat, pak dám přednost takovému engine, pro který jsou transakce přirozenou podstatou jeho fungování, ne takovému, na který byly uměle nalepeny po mnoha letech vysvětlování, že jsou vlastně k ničemu. Například už jen z představy, že by se v databázi mohlo transakční zpracování vztahovat jen na některé tabulky (a na jiné ne), mi běhá mráz po zádech.
    29.7.2005 09:18 Jan Kurik | blog: Hemis
    Rozbalit Rozbalit vše Postgresql
    Ja bych spise sel do bodu 2. Opravdu je to oproti MySQL rozdil.
    29.7.2005 10:22 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: Postgresql
    Rozdíl to je. Ale upřímně pochybuji, že tazatel ty fajnové věci opravdu potřebuje. Na 80% použití databází by stačilo i SQLite, byť si to zastánci PostgreSQL odmítají připustit. Jenže když si to někdo navrhne, že pro přidání dalšího jazyka potřebuje měnit strukturu tabulek a používat pohledy...
    15.3.2007 10:22 Libor
    Rozbalit Rozbalit vše Re: Povzdech nad "omezeností" MySQL
    Mno...jak na to tady koukam, tak docela čumím. Je jasné, že funkce gettext v php by docela postačovala, ale proč to neudělat řes mysql. Pokud se mrknete na www.wirphone.it, uvidíte, že to jde docela dobře. a to jen přes blblou funkci __("Překládaný text"). mno jo.

    A to, který jazyk se vybere záleží na jazykovém nastavení prohlížeče a nebo podle toho, jaky si návštěvník jazyk zvolí. Já myslím že mysql není zase tak špatný systém. Kdyby byl, určitě by neměl takovou komunitu jakou má. A pokud se to někomu nelíbí, tak at jde běhat s daty na antarktidu...výpomoc tučnákům....
    16.3.2007 20:44 Karel Benák | skóre: 8 | blog: benyho
    Rozbalit Rozbalit vše Re: Povzdech nad "omezeností" MySQL

    Gettext dokázal občas zazlobit a pěkně potrápit, kdysi jsem s ním měl nepříjemnou zkušenost.

    V současné době používám MySQL 4.X na jednu vícejazyčnou aplikaci a zdá se, že funguje velmi dobře. Ale občas mi v MySQL 4.X chybí pohledy a možnost napsat si vlastní uložené procedury abych nemusel řešit některé věci na straně PHP. Bohužel MySQL > 5.0 nemám na webhostingu k dispozici a nemůžu se zbavit dojmu, že se od páté verze konečně MySQL naučilo to, co už dlouho např. FireBird nebo PostgreSQL umí. Faktem je, že od 4.X udělala databáze MySQL obrovské kroky kupředu, doufám že neusne na vavřínech.

    Láska je jako prd, když hodně tlačiš tak z toho bude ...

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.