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 17:22 | Pozvánky

V sobotu 23. února se uskuteční 6. ročník WordCampu – největší konferenci o WordPressu v ČR. Ke konferenci probíhá i soutěž typu CTF (Capture The Flag) o volné vstupenky, kde si lze zkusit zneužít běžné bezpečnostní chyby.

smíťa | Komentářů: 0
dnes 17:11 | Pozvánky

Letošní ročník konference Prague PostgreSQL Developer Day se bude konat 13. a 14. února v prostorách FIT ČVUT. Program konference najdete na stránkách konference, stejně jako registrační formulář.

TomasVondra | Komentářů: 0
dnes 16:55 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě v nástroji pro správu databází v jednom PHP souboru Adminer. Chyba je už půl roku opravena. Stačí Adminer aktualizovat.

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

Byla vydána nová stabilní verze 2.7 svobodné decentralizované mikroblogovací platformy a sociální sítě podobné Twitteru Mastodon (Wikipedie). Detailní přehled novinek na GitHubu.

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

Byla vydána nová vývojová verze datového formátu a souvisejících nástrojů Relational pipes. Verze v0.9 obsahuje vstupní moduly pro fstab, CSV, XML a příkazový řádek; výstupní moduly pro CSV, XML, ODS (ODF), GUI (Qt), hodnoty oddělené nulovým bajtem a tabulkový výstup do konzole. Relační data lze upravovat relačními příkazy grep, cut a sed.

xkucf03 | Komentářů: 59
19.1. 18:33 | Zajímavý software

Podman dospěl do verze 1.0.0. Jedná se o nástroj umožňující vytvářet a provozovat kontejnery, aniž by uživatel potřeboval práva roota.

Ladislav Hagara | Komentářů: 1
18.1. 16:44 | Zajímavý software

Na Kickstarteru lze podpořit vývoj svobodného softwarového nástroje Akira, jenž by měl umožnit designérům designování aplikací v Linuxu. Mělo by se jednat o alternativu k proprietárním nástrojům Sketch, Figma nebo Adobe XD.

Ladislav Hagara | Komentářů: 0
18.1. 12:11 | Zajímavý článek

V Edici CZ.NIC vyšla kniha CyberSecurity věnovaná problematice kybernetické bezpečnosti, a to především jejím základním principům, které by měl respektovat každý, kdo využívá informační a komunikační technologie. Kniha je ke stažení zcela zdarma pod licenci Creative Commons (CC BY-ND 3.0 CZ) (pdf, epub, mobi).

Ladislav Hagara | Komentářů: 0
18.1. 02:00 | Nová verze

Byla vydána nová stabilní verze 0.92.4 a první alfa verze verze 1.0 svobodného multiplatformního vektorového grafického editoru Inkscape. Přehled novinek v poznámkách k vydání (0.92.4 a 1.0alpha0). Obě verze jsou k dispozici také jako balíčky ve formátu AppImage. Stačí je stáhnout, nastavit právo ke spuštění a spustit.

Ladislav Hagara | Komentářů: 6
17.1. 21:22 | Nová verze

Byla vydána verze 1.32 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

Ladislav Hagara | Komentářů: 0
Používáte USB Type-C?
 (20%)
 (16%)
 (11%)
 (12%)
 (37%)
 (4%)
 (43%)
Celkem 438 hlasů
 Komentářů: 0
Rozcestník

Dotaz: Postgresql vnořená funkce id sloupců

12.12.2018 12:04 ZAH | skóre: 42 | blog: ZAH
Postgresql vnořená funkce id sloupců
Přečteno: 213×
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: 42 | 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: 9
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: 42 | 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.