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 13:11 | Nová verze

Po téměř dvou letech byla vydána nová verze 4.0 linuxové distribuce Audiophile Linux (též AP-Linux-V4). Tato distribuce vychází z Arch Linuxu, používá systemd, správce oken Fluxbox a vlastní real-time jádro pro nižší latence. Z novinek můžeme jmenovat podporu nových procesorů Intel Skylake a Kaby Lake nebo možnost instalace vedle jiných OS na stejný disk. Pokud se zajímáte o přehrávání hudby v Linuxu, doporučuji návštěvu webu této

… více »
Blaazen | Komentářů: 7
27.4. 18:55 | Nová verze

Byla vydána nová stabilní verze 1.9 (1.9.818.44) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují podporu nového vyhledávače Ecosia. Ten z příjmů z reklam podporuje výsadbu stromů po celém světě (YouTube). Nově lze přeskupovat ikonky rozšíření nebo řadit poznámky. Nejnovější Vivaldi je postaveno na Chromiu 58.0.3029.82.

Ladislav Hagara | Komentářů: 20
27.4. 17:00 | Nová verze

Byla vydána verze 3.7.0 svobodného systému pro správu obsahu (CMS) Joomla!. V oznámení o vydání (YouTube) se píše o 700 vylepšeních. Opraveno bylo také 8 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 1
27.4. 08:22 | Komunita

Grsecurity (Wikipedie) je sada bezpečnostních patchů pro linuxové jádro (porovnání se SELinuxem, AppArmorem a KSPP). Od září 2015 nejsou stabilní verze těchto patchů volně k dispozici. Dle včerejšího oznámení (FAQ) nejsou s okamžitou platností volně k dispozici už ani jejich testovací verze.

Ladislav Hagara | Komentářů: 77
26.4. 23:33 | Komunita

OpenBSD 6.1 vyšlo již 11. dubna. Po dvou týdnech byla vydána i oficiální píseň. Její název je Winter of 95 a k dispozici je ve formátech MP3 a OGG.

Ladislav Hagara | Komentářů: 0
26.4. 18:55 | Nová verze

Byla vydána verze 2017.1 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux. S vydáním verze 2016.1 se Kali Linux stal průběžně aktualizovanou distribucí. Aktualizovat jej lze pomocí příkazů "apt update; apt dist-upgrade; reboot".

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

Po téměř pěti letech od vydání verze 2.00 byla vydána nová stabilní verze 2.02 systémového zavaděče GNU GRUB (GRand Unified Bootloader). Přehled novinek v souboru NEWS.

Ladislav Hagara | Komentářů: 28
26.4. 17:55 | Komunita

Vývojáři Debianu oznámili, že od 1. listopadu letošního roku nebudou jejich archivy dostupné pomocí protokolu FTP. Již v lednu oznámil ukončení podpory FTP kernel.org (The Linux Kernel Archives).

Ladislav Hagara | Komentářů: 29
26.4. 17:00 | Bezpečnostní upozornění

V oblíbeném webmailu postaveném na PHP SquirrelMail (Wikipedie) byla nalezena bezpečnostní chyba CVE-2017-7692, jež může být útočníkem zneužita ke spuštění libovolných příkazů a kompletnímu ovládnutí dotčeného serveru. Zranitelnost se týká pouze instancí, kde je pro transport používán Sendmail.

Ladislav Hagara | Komentářů: 3
26.4. 13:11 | Zajímavý článek

Soudní dvůr Evropské unie rozhodl (tisková zpráva) ve věci C-527/15: Prodej multimediálního přehrávače, který umožňuje zdarma a jednoduše zhlédnout na televizní obrazovce filmy protiprávně zpřístupněné na internetu, může představovat porušení autorského práva.

Ladislav Hagara | Komentářů: 32
Chystáte se pořídit CPU AMD Ryzen?
 (4%)
 (35%)
 (1%)
 (6%)
 (45%)
 (9%)
Celkem 347 hlasů
 Komentářů: 50, poslední 27.4. 04:06
    Rozcestník

    Dotaz: Jak v hstore najít klíče odpovídající reg. výrazu

    11.8.2011 00:25 Petr Bolf
    Jak v hstore najít klíče odpovídající reg. výrazu
    Přečteno: 295×
    Dobrý den, prosím o radu. Mám vytvořenou postgresql databázi projektu openstreetmap. Princip je takovýto, mám tři typy geografických objektů, node, way a relation. Můj problém je pro všechny tři typy stejný, takže dále budu hovořit jen o relations.

    Relation může mít libovolný počet tagů. Tag je údaj typu klíč: hodnota. V databázi to je řešeno takto:

    CREATE TABLE relations
    (
      id bigint NOT NULL,
      "version" integer NOT NULL,
      user_id integer NOT NULL,
      tstamp timestamp without time zone NOT NULL,
      changeset_id bigint NOT NULL,
      CONSTRAINT pk_relations PRIMARY KEY (id)
    )
    
    CREATE TABLE relation_tags
    (
      relation_id bigint NOT NULL,
      k text NOT NULL,
      v text NOT NULL
    )

    A já chci najít všechny relace, které nějak souvisí se železnicí, tedy mají klíč rail, railway, rail_station atd. Je to snadné:

    SELECT relation_id FROM relation_tags WHERE v LIKE 'rail%' GROUP BY relation_id ORDER BY relation_id

    No, jenže strukturu tabulky osm změnili tak, že místo tabulky pro tagy je sloupec typu hstore. To se mi líbí, ale mám problém.

    CREATE TABLE relations
    (
      id bigint NOT NULL,
      "version" integer NOT NULL,
      user_id integer NOT NULL,
      tstamp timestamp without time zone NOT NULL,
      changeset_id bigint NOT NULL,
      tags hstore, --- toto nahrazuje tabulku relation_tags
      CONSTRAINT pk_relations PRIMARY KEY (id)
    )
    V manuálu jsem našel dost informací. Umím třeba najít všechny řádky, které mají pro určitý klíč hodnotu odpovídající nějakému výrazu :

    SELECT id FROM relations WHERE ((tags->'route') LIKE 'rail%');

    Ale já nepotřebuji hodnoty, ale klíče a neznám název klíče. Umím najít všechny řádky s klíčem a pomocí OR bych to třeba nějak zvládl:

    SELECT id FROM relations WHERE tags ? 'rail' OR tags ? 'railway' ;

    ale vidíte, že to není dobrá cesta. Potřebuji najít řádky, které mají ve sloupci tags typu hstore rail%:

    SELECT id FROM relations WHERE tags ? 'rail%';

    Ale to takhle nefunguje. Řešení, která mně napadají jsou velice krkolomná. Lze to nějak snadno?

    díky moc

    Petr Bolf

    Řešení dotazu:


    Odpovědi

    Řešení 1× (l0gik)
    11.8.2011 01:34 l0gik | skóre: 22
    Rozbalit Rozbalit vše Re: Jak v hstore najít klíče odpovídající reg. výrazu
    Použij funkci each - rozvine Ti hstore zpátky na tabulku. Něco jako

    WHERE exists(SELECT key FROM each(tags) WHERE key LIKE 'rail%')

    Akorát to nebudeš moct rozumně zaindexovat, takže asi by si na to chtělo napsat SQL funkci a zaindexovat tu. Pokud ale hodláš vyhledávat ještě silniční, vodní a nevímjaké věci, pak bych si tam dal trigger na změnu hstore a udržoval vedle tabulku s typama.
    11.8.2011 12:15 Petr Bolf
    Rozbalit Rozbalit vše Re: Jak v hstore najít klíče odpovídající reg. výrazu
    Díky moc za nakopnutí. To je přesně ono. Asi mi to pořád myslí spíše v duchu MySQL, tak se dost ztrácím v těch možnostech PostgreSQL :-)

    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.