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 | Komunita

    Bylo oznámeno, že webový prohlížeč Opera GX zaměřený na hráče počítačových her je už také na Flathubu and Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 23:11 | IT novinky

    Akcionáři americké mediální společnosti Warner Bros. Discovery dnes schválili převzetí firmy konkurentem Paramount Skydance za zhruba 110 miliard dolarů (téměř 2,3 bilionu Kč). Firmy se na spojení dohodly v únoru. O část společnosti Warner Bros. Discovery dříve usilovala rovněž streamovací platforma Netflix, se svou nabídkou však neuspěla. Transakci ještě budou schvalovat regulační orgány, a to nejen ve Spojených státech, ale také

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 22:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 26.04 LTS Resolute Raccoon. Přehled novinek v poznámkách k vydání. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 11. vydání s dlouhodobou podporou (LTS).

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

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Gitea (Wikipedie) byla vydána v nové verzi 1.26.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Pozvánky

    Ve středu 29. dubna 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 7. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj i uživatelský prostor. Akce proběhne od 10:00 do večerních hodin. Hackday je určen všem zájemcům o praktickou práci s Linuxem na telefonech. Zaměří se na vývoj aplikací v userspace, například bankovní aplikace, zpracování obrazu z kamery nebo práci s NFC, i na úpravy

    … více »
    lkocman | Komentářů: 1
    22.4. 21:55 | Nová verze

    LilyPond (Wikipedie) , tj. multiplatformní svobodný software určený pro sazbu notových zápisů, byl vydán ve verzi 2.26.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    22.4. 20:33 | Nová verze

    Byla vydána nová verze 11.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 237 vývojářů. Provedeno bylo více než 2 500 commitů. Přehled úprav a nových vlastností v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    22.4. 13:33 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska oznámila, že si zajistila opci buď na akvizici startupu Cursor za 60 miliard dolarů (přes 1,2 bilionu Kč) do konce letošního roku, nebo na zaplacení deseti miliard dolarů za nové partnerství s touto firmou zabývající se generováním kódů. SpaceX se dále prosazuje na lukrativním trhu s vývojářskými nástroji pro umělou inteligenci (AI). Cursor, startup zabývající se prodejem modelů AI pro

    … více »
    Ladislav Hagara | Komentářů: 2
    22.4. 13:11 | Komunita

    Díky AI modelu Claude Mythos Preview od společnost Anthropic bylo ve Firefoxu nalezeno a opraveno 271 zranitelností.

    Ladislav Hagara | Komentářů: 6
    22.4. 04:44 | Nová verze

    Byla vydána nová verze 2.54.0 distribuovaného systému správy verzí Git. Přispělo 137 vývojářů, z toho 66 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1399 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: 1039×
    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.