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 20:11 | Komunita

    Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma. V Týdnu v GNOME je zmíněn flatpak balíček pro GIMP 0.54.1 z roku 1996. Jedná se o poslední verzi GIMPu postavenou nad toolkitem Motif.

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

    Home Assistant Operating System, tj. linuxová distribuce optimalizována pro hostování Home Assistanta a jeho aplikací, byl vydán v nové major verzi 18.0.

    Ladislav Hagara | Komentářů: 0
    včera 18:11 | Komunita

    Po šestiletém úsilí byla z jádra Linux odstraněna funkce strncpy(). Všechna předchozí volání této funkce byla převedena na bezpečnější alternativy.

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

    Byla vydána nová verze 261 správce systému a služeb systemd (Wikipedie, GitHub). Z novinek lze vypíchnout nový subsystém IMDS (Cloud "Instance Metadata Service"), nový příkaz storagectl nebo novou komponentu systemd-sysinstall.

    Ladislav Hagara | Komentářů: 2
    včera 12:00 | Nová verze

    Vývojové prostředí Qt Creator bylo vydáno ve verzi 20 (seznam změn). Novinky zahrnují hlavně rozšíření pro integraci LLM agentů nebo minimalistický editační režim uživatelského rozhraní („zen mode“).

    |🇵🇸 | Komentářů: 0
    19.6. 10:22 | Humor

    Už jste se prolétli na webu Google Earth? Přibyl tam Simulátor letu (Nástroje / Simulátor letu). Funguje i bez účtu Google [𝕏].

    Ladislav Hagara | Komentářů: 0
    19.6. 09:55 | Nová verze

    Byla vydána nová verze 4.7 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 3
    18.6. 13:33 | Nová verze

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.6. Přehled novinek s náhledy v oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    18.6. 12:44 | IT novinky

    V Edici CZ.NIC, knižní řady správce české národní domény, vychází nová kniha Martina Malého Kódy, buildy, firmwary. Autor po půl roce od vydání předchozího titulu přichází se svou již sedmou knihou, tentokrát zaměřenou na vývoj programového vybavení pro embedded zařízení. Publikace s podtitulem Základy vývojářského řemesla pro tvůrce hobby elektroniky nabízí praktického průvodce pro všechny, kdo své projekty vytvořené s Arduinem

    … více »
    Ladislav Hagara | Komentářů: 0
    18.6. 11:44 | Komunita

    V Brně na FIT VUT probíhá dvoudenní open source komunitní konference DevConf.CZ 2026. Na programu je celá řada zajímavých přednášek, lightning talků, meetupů a workshopů. Přednášky lze sledovat i online na YouTube kanálu konference. Aktuální dění lze sledovat na Matrixu, 𝕏 nebo Mastodonu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1950 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Postgresql vnořená funkce id sloupců

    12.12.2018 12:04 ZAH | skóre: 43 | blog: ZAH
    Postgresql vnořená funkce id sloupců
    Přečteno: 1043×
    Zasek jsem se nad vnořenými funkce v Postgreql 9.1

    Mám základní funkci, která pracuje bez problémů
    CREATE FUNCTION accounting.basefun(
        IN var_year character,
        IN var_month character)
      RETURNS TABLE(
      account  character,
      debit11  double precision, 
      credit11 double precision,
      debit    double precision, 
      credit   double precision,
      debitxx  double precision, 
      creditxx double precision) AS
    $BODY$
    .....
    ......
    
    Nyní potřebuji ji použít jako zdroj dat v jiné funkci , tam jsem narazil na problém s identifikací sloupců.
     CREATE FUNCTION extfun(
        IN var_year character,
        IN var_month character)
      RETURNS TABLE(
      account  character,
      accountname  character,
      debit11  double precision, 
      credit11 double precision,
      debit    double precision, 
      credit   double precision,
      debit1x  double precision, 
      credit1x double precision, 
      debitxx  double precision, 
      creditxx double precision,
      debitact  double precision, 
      creditact double precision
      ) AS
    $BODY$
    SELECT
     ledg.account, //error
     Zde nemohu přijít jak identifikovat sloupce
     ledg.debit11,
     ledg.credit11 
    .........
    FROM 
     (SELECT 
      accounting.basechangeledger(var_year,var_month)
    ) AS ledg 
    $BODY$
    
    Předem dík za nakopnutí správným směrem.

    Řešení dotazu:


    Odpovědi

    12.12.2018 15:17 ttt
    Rozbalit Rozbalit vše Re: Postgresql vnořená funkce id sloupců
     (SELECT 
      * 
      FROM
      accounting.basechangeledger(var_year,var_month)
    ) AS ledg 
    Tvůj zápis sešrotuje sloupce do pole a vrací to jako jeden sloupec, jestli se nepletu.
    12.12.2018 19:55 ZAH | skóre: 43 | blog: ZAH
    Rozbalit Rozbalit vše Re: Postgresql vnořená funkce id sloupců
    Nezdá se, přiložená funkce vrací normálně tabulku identickou s výsledkem accounting.basefunc (zdroj from). Vtip je v tom, že potřebuji doplnit několik sloupců a tak potřebuji přístup k datům vnitřní funkce v select. Řešením je přepsání původní funkce tak aby obsahovala doplněné sloupce což úplně nevyhovuje.
    CREATE  FUNCTION  accounting.test(
        IN var_year character,
        IN var_month character)
      RETURNS TABLE(
      account  character,
      debit11  double precision, 
      credit11 double precision,
      debit    double precision, 
      credit   double precision,
      debitxx  double precision, 
      creditxx double precision
      ) AS
    $BODY$
    SELECT 
    *
    FROM 
     (SELECT 
      accounting.basefunc(var_year,var_month)
    ) AS ledg 
    
    
    $BODY$
     LANGUAGE sql VOLATILE
    
    Řešení 1× (ZAH (tazatel))
    12.12.2018 20:43 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: Postgresql vnořená funkce id sloupců
    Funkcia ano, ale tvoj pod-dotaz SELECT accounting.basefunc(var_year,var_month) vola funkciu vracajucu "sadu" (set returning function). Ak ju zavolas priamo v SELECT klauzule, tak musi vratit cely viacstlpcovy riadok v jedinom stlpci typu ROW(*). Predrecnik to sice chybne oznacil ako pole, ale trafil pricinu problemu. Je to to iste, ako keby si zavolal SELECT ROW(e.*) FROM accounting.basefunc(var_year,var_month);

    Ak chces pracovat s jednotlivymi stlpcami, musis to volat ako SELECT * FROM accounting.basefunc(var_year,var_month).

    Tvoja funkcia by potom mohla vyzerat takto:
    BODY$
    SELECT
     ledg.*,
     ledg.debit11,
     ledg.credit11
    FROM 
     (SELECT *
      FROM accounting.basechangeledger(var_year,var_month)
    ) AS ledg 
    $BODY$
    
    co je ale to iste ako:
    BODY$
    SELECT
     ledg.*,
     ledg.debit11,
     ledg.credit11
    FROM accounting.basechangeledger(var_year,var_month) AS ledg 
    $BODY$
    
    12.12.2018 21:18 ZAH | skóre: 43 | blog: ZAH
    Rozbalit Rozbalit vše Re: Postgresql vnořená funkce id sloupců
    Dík máš plnou pravdu.

    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.