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 19:44 | Zajímavý článek

    Před 32 lety, 6. června 1993, byl spuštěn první český WWW server (ještě pod TLD .cs), pro potřeby fyziků zabývajících se problematikou vysokých energií.

    Ladislav Hagara | Komentářů: 4
    včera 16:11 | Zajímavý software

    Střílečku Borderlands 2 lze v rámci výprodeje série Borderlands na Steamu získat zdarma napořád, když aktivaci provedete do 8. června 19:00.

    Ladislav Hagara | Komentářů: 3
    včera 15:11 | Nová verze

    Byla vydána nová verze 2.22 svobodného video editoru Flowblade (GitHub, Wikipedie). Přehled novinek v poznámkách k vydání. Videoukázky funkcí Flowblade na Vimeu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 1
    5.6. 15:00 | Komunita

    Canonical Launchpad vypíná systém správy verzí Bazaar. Vývojáři mohou své repozitáře do 1. září přemigrovat na Git.

    Ladislav Hagara | Komentářů: 7
    5.6. 13:22 | Nová verze

    Byla vydána nová verze 2.53.21 svobodného multiplatformního balíku internetových aplikací SeaMonkey (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 4
    5.6. 12:33 | Komunita Ladislav Hagara | Komentářů: 16
    5.6. 11:22 | Komunita

    Na Indiegogo byla spuštěna kampaň na podporu linuxového telefonu Liberux NEXX s osmijádrovým procesorem Rockchip RK3588S, 32 GB LPDDR4x RAM a 6.34″ 2400×1080 OLED displejem. Cena telefonu je 1 310 eur.

    Ladislav Hagara | Komentářů: 4
    5.6. 11:11 | Komunita

    Miro Hrončok vyhrál volby do Fedora Council. Mezi sedmi kandidáty, kteří se ucházeli o dvě křesla, nakonec získal nejvíce hlasů - 1089. Česká komunita má tak po delší době opět zástupce v nejvyšším orgánu Fedory.

    Ladislav Hagara | Komentářů: 0
    5.6. 04:33 | Zajímavý software

    Redox OS (Wikipedie), tj. mikrokernelový unixový operační systém naprogramovaný v programovacím jazyce Rust, nově podporuje X11 a GTK 3.

    Ladislav Hagara | Komentářů: 0
    5.6. 02:55 | IT novinky

    Dnes po celém světě startuje prodej herní konzole Nintendo Switch 2.

    Ladislav Hagara | Komentářů: 10
    Jaký je váš oblíbený skriptovací jazyk?
     (54%)
     (33%)
     (7%)
     (2%)
     (0%)
     (0%)
     (3%)
    Celkem 219 hlasů
     Komentářů: 14, poslední 2.6. 08:30
    Rozcestník

    Zlobivý PostgreSQL

    4.11.2006 10:31 | Přečteno: 1041× | OpenSource | poslední úprava: 4.11.2006 19:31

    A minulém týdny mi náhle začal zlobit slovníkový editor. Dámy z UJČ vyplašeně hlásily, že jim slovník sežral jejich hesla. Já zůstával v klidu, mám přece zálohy a journal v podobě podrobného logu, který bych v nejhorším případě přehrál.

    Vypadalo to, že postgres nesouhlasí ze zásadní tezí, totiž že 'BŘEZIŇÁK' == 'BŘEZIŇÁK'

    slovnik=> select '-'||heslove_slovo||'-' from entries where heslove_slovo='BŘEZIŇÁK';
     ?column? 
    ----------
    (0 řádek)
    
    slovnik=> select '-'||heslove_slovo||'-' from entries where heslove_slovo like 'BŘEZIŇÁK';
      ?column?  
    ------------
     -BŘEZIŇÁK-
    (1 řádka)
    

    Po zmateném googlovaní jsem se odhodlal k podrobnějšímu ohledání a hned jsem pojal podezření na index.

    slovnik=> select '-'||heslove_slovo||'-' from entries where heslove_slovo||'' = 'BŘEZIŇÁK';
      ?column?  
    ------------
     -BŘEZIŇÁK-
    (1 řádka)
    

    To se také potvrdilo: při použití seq scan je výsledek správný, při index scan špatný

    slovnik=> explain select '-'||heslove_slovo||'-' from entries where heslove_slovo = 'BŘEZIŇÁK';
                                             QUERY PLAN                                         
    --------------------------------------------------------------------------------------------
     Index Scan using entries_heslove_slovo_index on entries  (cost=0.00..5.97 rows=1 width=12)
       Index Cond: ((heslove_slovo)::text = 'BŘEZIŇÁK'::text)
    (2 řádek)
    
    slovnik=> explain select '-'||heslove_slovo||'-' from entries where heslove_slovo||'' = 'BŘEZIŇÁK';
                                 QUERY PLAN                             
    --------------------------------------------------------------------
     Seq Scan on entries  (cost=0.00..272.04 rows=37 width=12)
       Filter: (((heslove_slovo)::text || ''::text) = 'BŘEZIŇÁK'::text)
    (2 řádek)
    
    slovnik=> explain select '-'||heslove_slovo||'-' from entries where heslove_slovo like 'BŘEZIŇÁK';
                            QUERY PLAN                        
    ----------------------------------------------------------
     Seq Scan on entries  (cost=0.00..253.38 rows=1 width=12)
       Filter: ((heslove_slovo)::text ~~ 'BŘEZIŇÁK'::text)
    (2 řádek)
    

    Nakonec jsem se naučil nový SQL příkaz:

    slovnik=> \h reindex
    Příkaz:     REINDEX
    Popis:      rebuild indexes
    Syntaxe:
    REINDEX { DATABASE | TABLE | INDEX } name [ FORCE 
    

    Po reindexaci tabulky je zaze BŘEZIŇÁK BŘEZIŇÁKem.

    Postgresql 8.1 je určitě výrazný krok vpřed proti verzi 7.4, kterou jsem používal dřív. Kromě kupy nových funkcí, které stejně neocením, protože nejsem žádný DB guru, oceňuji subjektivní zrychlení (všimli si ho i koncoví uživatelé) a autovacoom. Nicméně jestě je určitě co dohánět. Lookupy přes index nefungovaly a v logu přitom nebylo žádné varování, nepříjemná záležitost...

           

    Hodnocení: 89 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    4.11.2006 14:09 Jan Pekar (Johny_5)
    Rozbalit Rozbalit vše Re: Zlobivý PostgreSQL
    Taky jsem se divil, ze vyhledani pres LIKE fungovalo, ale porovnani ne. Po provedeni EXPLAIN query nam doklaplo, kde by mohl byt problem. Od ted vsem doporucuji, aby provedli REINDEX po kazdem upgrade postgresu. Skoda jen, ze to neudela sam a ze to pro zakaznika vypadalo, jako chyba (vypadek sluzby).
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.