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 11:11 | Zajímavý článek

Společnost Latacora věnující se počítačové bezpečnosti publikovala na svém blogu článek The PGP Problem poukazující na nedostatky PGP, OpenPGP a GnuPG. Článek obsahuje jak odkazy na další zajímavé články, tak i odkazy na alternativní softwarové produkty: Magic Wormhole pro přenos souborů, Tarsnap pro zálohování, Signify nebo Minisign pro podepisování balíčků, kryptografickou knihovnu libsodium nebo nástroj age pro šifrování souborů [Hacker News].

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

KDE Plasma 5 slaví 5 let. Verze 5.0 byla vydána v červenci 2014. Aktuálně poslední je verze 5.16 z června letošního roku. Připomenutí jednotlivých verzi ve videu na YouTube nebo na PeerTube.

Ladislav Hagara | Komentářů: 1
včera 15:55 | Nová verze

Byla vydána verze 6.0 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu.

Ladislav Hagara | Komentářů: 0
včera 11:33 | Zajímavý článek

Benson Leung řeší na people.kernel.org Kolik je druhů USB-C do USB-C kabelů? TL;DR: Je jich 6 a pro uživatele je to docela matoucí.

Ladislav Hagara | Komentářů: 7
15.7. 23:00 | Zajímavý článek

Richard M. Stallmanrozhovoru pro Opensource.com vysvětluje svou roli v návrhu standardu POSIX a vztah mezi projektem GNU a POSIX. V článku jsou pak vyjmenovány příklady funkcí nástrojů GNU, které byly do standardu přijaty.

Fluttershy, yay! | Komentářů: 0
15.7. 19:11 | Komunita

Nadace Blender Foundation oznámila, že společnost Epic Games vyvíjející počítačové hry věnuje v rámci svého programu Epic MegaGrants 1,2 milionu dolarů na vývoj svobodného 3D softwaru Blender.

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

Článek Co je Silverblue? na MojeFedora.cz odpovídá na otázky kolem tohoto projektu. Silverblue je oficiální název pro novou generaci desktopového operačního systému, dříve známého jako Atomic Workstation. Celý základní operační systém je v Silverblue dodáván ve formě obrazů, které jsou vytvářeny za použití projektu rpm-ostree. Hlavními přednostmi jsou jeho rychlost, bezpečnost, atomické aktualizace a neměnnost.

Ladislav Hagara | Komentářů: 12
15.7. 11:00 | Humor

Jak na uživatelsky přívětivý web? Projít si User Inyerface aneb UX peklo a nikdy nic z toho nepoužít.

Ladislav Hagara | Komentářů: 8
15.7. 10:22 | Zajímavý software

Byla vydána verze 0.6.0 textového editoru Amp inspirovaného editorem Vim a naprogramovaného v programovacím jazyce Rust. Přehled novinek na GitHubu.

Ladislav Hagara | Komentářů: 1
13.7. 18:44 | Nová verze

Bylo vydáno OpenHMD 0.3.0 s kódovým názvem Djungelvral. Jedná se o svobodný software pro podporu zařízení s HMD (Head-mounted display) pro pohlcující virtuální a rozšířenou realitu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí Boost.

Ladislav Hagara | Komentářů: 0
Používáte ještě 32bitový software na PC?
 (20%)
 (17%)
 (22%)
 (44%)
 (7%)
 (30%)
Celkem 81 hlasů
 Komentářů: 8, poslední dnes 02:18
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: 414×
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: 10
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.