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 07:00 | Nová verze

Dnes odpoledne vyjde Mozilla Firefox 75.0. Oficiální verze ve formátu Flatpak je již k dispozici na Flathubu. Přehled novinek bude zveřejněn v poznámkách k vydání a na stránce věnované vývojářům.

Ladislav Hagara | Komentářů: 0
včera 18:44 | IT novinky

Paul Cormier je novým prezidentem a CEO společnosti Red Hat. Jim Whitehurst je prezidentem IBM.

Ladislav Hagara | Komentářů: 6
včera 17:22 | Humor

Lukáš Churý připravil malou pátrací hru. Je určená hlavně pro webaře. Zahrát si ji ale může každý, kdo má alespoň základní ponětí o HTML.

Ladislav Hagara | Komentářů: 28
včera 08:00 | Zajímavý software

Byla vydána verze 0.5.0 jednoduchého a uživatelsky přívětivého Jabber/XMPP klienta Kaidan postaveného na Kirigami a QtQuick. Zdrojové kódy jsou k dispozici na GitLabu.

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

Aplikace pro čtení elektronických knih Foliate, založená na knihovně Epub.js, vyšla ve verzi 2.0, která přináší přepracované uživatelské rozhraní a řadu drobných vylepšení.

Fluttershy, yay! | Komentářů: 11
4.4. 18:44 | Bezpečnostní upozornění

Twitter upozornil, že pokud se uživatel Twitteru přihlašoval ve Firefoxu na sdíleném nebo veřejném počítači, tak po odhlášení se z Twitteru mohla na disku zůstat nakešovaná citlivá data, a proto toto kešování pro Firefox zakázal. Reakce Mozilly: Twitter by měl prostě dodržovat standardy.

Ladislav Hagara | Komentářů: 4
4.4. 17:44 | Zajímavý článek

Článek na Jitsi je věnován bezpečnosti a soukromí uživatelů při používání videokonferenčního softwaru Jitsi Meet. Doporučuje se zamyslet nad názvem místnosti. Upozorňuje, že místnost existuje, pouze pokud se v ní někdo nachází. V případě nastavení hesla, je toto heslo s ukončením místnosti zapomenuto a při opětovném použití místnosti je nutno jej opět zadat.

Ladislav Hagara | Komentářů: 2
4.4. 06:00 | IT novinky

Na Indiegogo byla spuštěna kampaň na podporu chytrého telefonu a kapesního počítače Astro Slide 5G Transformer od společnosti Planet Computers. Požadovaná částka 180 000 eur byla vybrána během 4 hodin. Stejně jako u předchozích zařízení Gemini PDA a Cosmo Communicator od této společnosti je slíbená podpora Linuxu.

Ladislav Hagara | Komentářů: 18
3.4. 19:22 | Zajímavý software

CryptPad je svobodný online kancelářský balík. Zdrojové kódy jsou k dispozici na GitHubu pod licencí AGPL-3.0. Oficiální instance nově nabízí 1 GB prostoru. Mozilla Foundation tento týden věnovala projektu 10 000 $.

Ladislav Hagara | Komentářů: 2
3.4. 18:22 | Nová verze

Byla vydána finální beta verze Ubuntu 20.04 LTS s kódovým názvem Focal Fossa. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 20.04 mělo vyjít 23. dubna 2020.

Ladislav Hagara | Komentářů: 6
Chodíte do práce?
 (27%)
 (1%)
 (4%)
 (3%)
 (46%)
 (14%)
 (5%)
Celkem 185 hlasů
 Komentářů: 4, poslední 2.4. 14:20
Rozcestník

www.AutoDoc.Cz

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: 549×
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.