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 04:44 | Nová verze

    Byla vydána nová verze 2.4.68 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 13 zranitelností.

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

    Apple na své vývojářské konferenci WWDC26 (Worldwide Developers Conference, keynote) představil řadu novinek. Vypíchnout lze novou generaci Apple Intelligence a zbrusu novou Siri, která dostala název Siri AI. Kvůli Aktu o digitálních trzích (DMA) však funkce Siri AI nebudou v systémech iOS 27 a iPadOS 27 k dispozici uživatelům v Evropské unii.

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

    Byla vydána nová verze 1.18.0 distribučního frameworku Flatpak (Wikipedie), tj. technologie umožňující distribuovat aplikace v podobě jednoho instalačního souboru na různé linuxové distribuce a jejich různá vydání. Přehled novinek na GitHubu. Vypíchnout lze podporu rozhraní /dev/kfd pro výpočty na kartách AMD (AMDKFD).

    Ladislav Hagara | Komentářů: 0
    včera 20:44 | Nová verze

    aMule (Wikipedie), tj. multiplatformní klient pro peer-to-peer sdílení souborů pro sítě eD2k and Kademlia, byl po více než pěti letech od vydání poslední verze 2.3.3, vydán v nové major verzi 3.0.0 (GitHub). S novou webovou stránkou a dokumentací.

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

    Byly vyhlášeni vítězové a zveřejněny vítězné zdrojové kódy (YouTube, GitHub) již 29. ročníku soutěže International Obfuscated C Code Contest (IOCCC), tj. soutěže o nejnepřehlednější (nejobfuskovanější) zdrojový kód v jazyce C.

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | IT novinky

    Evropská komise předložila evropský balíček pro technologickou suverenitu, tedy soubor opatření, která mají posílit kapacity EU v oblasti polovodičů, umělé inteligence, cloudu a open source. To Evropě pomůže stát se lídrem v oblasti umělé inteligence, posílit její digitální autonomii a vytvářet podmínky pro udržitelnější digitální budoucnost.

    Ladislav Hagara | Komentářů: 11
    včera 04:44 | Nová verze

    OpenCV (Open Source Computer Vision, Wikipedie), tj. open source multiplatformní knihovna pro zpracování obrazu a počítačové vidění, byla vydána v nové major verzi 5.

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

    Byla vydána nová verze 9.7 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    5.6. 18:22 | Komunita

    Vývojáři webového prohlížeče Ladybird dnes oznámili, že mění způsob vývoje. S blížícím se vydáním alfa verze přestávají přijímat veřejné pull requesty. Všechny otevřené veřejné pull requesty budou uzavřeny. Tým nedokáže garantovat bezpečnost AI generovaných pull requestů.

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

    OpenLogi (GitHub) je open source náhrada aplikace Logi Options+ pro přizpůsobení myší od společnosti Logitech. Zatím běží pouze na macOS.

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1853 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    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: 394×
    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.