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 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 10
    15.8. 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 6
    15.8. 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    15.8. 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 10
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 26
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (2%)
     (1%)
     (1%)
     (17%)
    Celkem 404 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: PostgreSQL a dědičnost

    xkucf03 avatar 23.11.2008 01:37 xkucf03 | skóre: 49 | blog: xkucf03
    PostgreSQL a dědičnost
    Přečteno: 724×
    Ahoj. Chtěl jsem použít dědičnost v PostgreSQL tak, abych měl tabulku obecných objektů (předka) a pak tabulku článků (potomek) a později další potomky objektů. S tím, že na objekty bych třeba mohl navázat komentáře nebo hodnocení a nemusel bych tohle dělat pro každého potomka zvlášť.

    Tabulky vypadají takhle:
    CREATE TABLE objekt
    (
      id numeric NOT NULL, -- Identifikace jedinečná pro všechny objekty v systému
      nazev character varying, -- Název objektu
      CONSTRAINT objekt_pk PRIMARY KEY (id)
    )
    WITH (OIDS=FALSE);
    ALTER TABLE objekt OWNER TO piskoviste;
    COMMENT ON COLUMN objekt.id IS 'Identifikace jedinečná pro všechny objekty v systému';
    COMMENT ON COLUMN objekt.nazev IS 'Název objektu';
    
    CREATE TABLE clanek
    (
    -- Inherited:   id numeric NOT NULL,
    -- Inherited:   nazev character varying,
      "text" text, -- Text článku
      CONSTRAINT clanek_pk PRIMARY KEY (id)
    )
    INHERITS (objekt)
    WITH (OIDS=FALSE);
    ALTER TABLE clanek OWNER TO piskoviste;
    COMMENT ON COLUMN clanek."text" IS 'Text článku';
    Problém ale je, že primární klíč funguje jen na danou tabulku, např. předka a nezabrání tomu, abych měl objekt s id = 1 a článek s id = 1 a pak když selektuji všechny objekty (včetně článků), dostanu výstup s duplicitními id.

    Další problém bude s cizími klíči, když budu chtít navázat třeba ty komentáře na objekt.

    Samozřejmě jsem udělal RTFM a zjistil jsem, že oficiální dokumentace tyhle problémy popisuje. Řešení ale chybí, jen se tam píše, že tyhle nedostatky budou napraveny někdy v příštích verzích.

    Existuje nějaký způsob, jak dědičnost využít k mému účelu, nebo se na to mám vykašlat a udělat to klasicky*? Případně použít jako identifikátor OID? Ale nevím, jak moc dobré řešení to je (řešilo by to PK, ale ne FK).

    *) Víc tabulek provázaných přes cizí klíče, kde „potomci“ budou mít jako PK cizí klíč do tabulky „předka“ + nějaké pohledy, které udělají souhrn společných sloupečků všech potomků.
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes

    Odpovědi

    xkucf03 avatar 23.11.2008 01:43 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Seznam objektů včetně jejich typu
    BTW: tohle funguje podle mých představ:
    SELECT o.*, pg_class.relname
    FROM objekt o
    JOIN pg_class ON (o.tableoid = pg_class.oid);
    …seznam objektů včetně jejich typu (resp. názvu tabulky)
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    xkucf03 avatar 23.11.2008 11:05 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Pomocná tabulka objekt_id

    Ještě před usnutím mě jedno řešení napdalo: vytvořím si pomocnou tabulku objekt_id, která bude obsahovat seznam ID objektů, a funkci zalozObjekt(), která vezme nové ID ze sekvence a zároveň založí záznam v objekt_id. Tuhle funkci použiji jako výchozí hodnotu sloupečku místo přímého selektování sekvence.

    CREATE SEQUENCE komentar_seq
      INCREMENT 1
      MINVALUE 1
      MAXVALUE 9223372036854775807
      START 1
      CACHE 1;
    
    
    CREATE SEQUENCE objekt_seq
      INCREMENT 1
      MINVALUE 1
      MAXVALUE 9223372036854775807
      START 2
      CACHE 1;
    
    
    CREATE TABLE objekt_id
    (
      id bigint NOT NULL,
      CONSTRAINT objekt_id_pk PRIMARY KEY (id),
      CONSTRAINT objekt_fk FOREIGN KEY (id)
          REFERENCES objekt_id (id) MATCH SIMPLE
          ON UPDATE NO ACTION ON DELETE NO ACTION
    )
    WITH (OIDS=FALSE);
    COMMENT ON TABLE objekt_id IS 'Tabulka navíc, abychom obešli problém s PK a dědičností.
    Žádná data, jen seznam primárních klíčů objektů';
    
    
    CREATE OR REPLACE FUNCTION zalozobjekt()
      RETURNS bigint AS
    $BODY$DECLARE id BIGINT;
    BEGIN
        SELECT INTO id nextval('objekt_seq');
        INSERT INTO objekt_id VALUES (id);
        return id;
    END;$BODY$
      LANGUAGE 'plpgsql' VOLATILE
      COST 100;
    
    
    CREATE TABLE objekt
    (
      id bigint NOT NULL DEFAULT zalozobjekt(), -- Identifikace jedinečná pro všechny objekty v systému
      nazev character varying, -- Název objektu
      CONSTRAINT objekt_pk PRIMARY KEY (id),
      CONSTRAINT clanek_fk FOREIGN KEY (id)
          REFERENCES objekt_id (id) MATCH SIMPLE
          ON UPDATE NO ACTION ON DELETE NO ACTION
    )
    WITH (OIDS=FALSE);
    COMMENT ON COLUMN objekt.id IS 'Identifikace jedinečná pro všechny objekty v systému';
    COMMENT ON COLUMN objekt.nazev IS 'Název objektu';
    
    CREATE TABLE clanek
    (
    -- Inherited:   id bigint NOT NULL,
    -- Inherited:   nazev character varying,
      "text" text, -- Text článku
      CONSTRAINT clanek_pk PRIMARY KEY (id)
    )
    INHERITS (objekt)
    WITH (OIDS=FALSE);
    COMMENT ON COLUMN clanek."text" IS 'Text článku';
    
    CREATE TABLE komentar
    (
      id bigint NOT NULL DEFAULT nextval('komentar_seq'::regclass),
      nadpis character varying NOT NULL,
      "text" text NOT NULL,
      objekt bigint NOT NULL,
      odpoved_na bigint,
      CONSTRAINT komentar_pk PRIMARY KEY (id),
      CONSTRAINT komentar_objekt_fk FOREIGN KEY (objekt)
          REFERENCES objekt_id (id) MATCH SIMPLE
          ON UPDATE NO ACTION ON DELETE NO ACTION,
      CONSTRAINT komentar_odpoved_fk FOREIGN KEY (odpoved_na)
          REFERENCES komentar (id) MATCH SIMPLE
          ON UPDATE NO ACTION ON DELETE NO ACTION
    )
    WITH (OIDS=FALSE);
    
    CREATE INDEX fki_komentar_objekt_fk
      ON komentar
      USING btree
      (objekt);
    
    CREATE INDEX fki_komentar_odpoved_fk
      ON komentar
      USING btree
      (odpoved_na);
    
    CREATE OR REPLACE VIEW trida_objektu AS
     SELECT o.id, o.nazev, pg_class.relname
       FROM objekt o
       JOIN pg_class ON o.tableoid = pg_class.oid;

    Zatím to vypadá, že to funguje – řeší to problém jedinečnosti ID přes předka a všechny potomky a problém s cizími klíči (např. navázání komentářů).
    Ale přijde mi to jako dost velká obebávka, tak by mě zajímalo, co si o tom myslí Pavel Stěhule nebo někdo podobný :-)

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    23.11.2008 14:26 Pavel Stěhule
    Rozbalit Rozbalit vše Re: Pomocná tabulka objekt_id

    S dědičností je to asi tak - když jsem si poprvně přečetl manuál, řekl jsem si super. A než jsem se dostal k projektu, kde bych ji mohl použít, tak jsem krapet vystřízlivěl. Dědičnost má smysl, tam kde mám dynamické schéma - tj. kde využiju toho, že po přidání potomka vidím data i v rodiči. Jinak nevidím důvod ji použít. A ohledně té obebavky - s Petrem Krontorádem http://www.krontorad.com/ jsme vymýšleli objektový db backend pro menší aplikace. Výsledná struktura byla docela podobná. Šli jsme na to o fous univerzálněji - měli jsme popisný jazyk pro popis objektů - skripty v něm se po vykonání přeložily v SQL příkazy, které jednak vytvářely podobné schéma, jednak plnily tabulky s metadaty, vytvářely potřebné indexy, atd.

    Funkci zaloz_objekt bych asi napsal o něco úsporněji (všechny tři příkazy lze sloučit do jednoho pomocí klauzule RETURNING):

     

    xkucf03 avatar 23.11.2008 15:10 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Pomocná tabulka objekt_id

    Díky za odpověď. Schchéma až tak dynamické nebude, ale asi u dědičnosti zůstanu, pokud se neobjeví nějaký velký problém (líbí se mi např. ten snadný způsob zjištění typu objektu pomocí pohledu).

    Ještě bych měl dotaz: nějak cítím, že by bylo systémově lepší, kdyby potomkem objektu byly úplně všechny objekty v systému (včetně komentářů, hlasování atd.). Ale tyhle věci jako objekty mít nepotřebuji a navíc se obávám, že by tabulka objekt_id narostla do zbytečně velkých rozměrů a nic by to nepřineslo. Naopak by její velikost mohla způsobovat zpomalení. Co bys volil ty – univerzální řešení (všechno je potomkem objektu) nebo mít jako objekty jen ty tabulky, u kterých to má smysl?

     

     

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    okbob avatar 24.11.2008 11:22 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Pomocná tabulka objekt_id

    To vubec nedokazu rict - je to otazka citu - treba komentare beru spise jen jako property u clanku (ale zalezi na kontextu). Pokud uz bych ale pracoval s objekty - tak spis bych vychazel z jednoho predka - to ostatni bych vubec nepovazoval za objekty.

    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.