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 23:33 | IT novinky

Poslanecká sněmovna bude projednávat vládní návrh novely zákona č. 289/2005 Sb., o Vojenském zpravodajství, který by právě Vojenskému zpravodajství dal možnost sledovat síťový provoz a provádět aktivní zásahy v kyberprostoru. Okolnostmi předložení novely a kontroverzí v jejím obsahu rozebírá např. Jan Cibulka na iRozhlasu, a to včetně kritizované nedostatečné kontroly.

Fluttershy, yay! | Komentářů: 0
včera 22:00 | Nová verze

Byla vydána verze 2.27.0 distribuovaného systému správy verzí Git. Přispělo 71 vývojářů, z toho 19 nových. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
včera 16:22 | Upozornění

V rámci projektu ADAM (Advanced DNS Analytics and Measurements) uvádí Laboratoře CZ.NIC ve spolupráci s CSIRT.CZ do produkčního provozu nástroj DNS crawler. Záměrem je periodicky procházet všechny domény 2. úrovně pod TLD .cz, získávat o nich různá veřejně dostupná data a ta pak dále zpracovávat. I když to jeho jméno přímo nenapovídá, DNS crawler bude kromě sběru dat z DNS také komunikovat s webovým a e-mailovým serverem každé domény.

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

Po 9 týdnech vývoje od vydání Linuxu 5.6 oznámil Linus Torvalds vydání Linuxu 5.7 (LKML). Přehled nových vlastností a vylepšení na stránce Linux Kernel Newbies. Kódové jméno Linuxu 5.7 zůstává Kleptomaniac Octopus.

Ladislav Hagara | Komentářů: 2
včera 00:22 | Komunita

Byl aktualizován styl zápisu zdrojových kódů Linuxu. Maximální počet znaků (sloupců) na řádek byl zvýšen z 80 na 100. Preferováno ale zůstává 80 znaků [reddit].

Ladislav Hagara | Komentářů: 18
31.5. 23:44 | Komunita

Vývojáři postmarketOS (GitLab) hodnotí tři roky vývoje tohoto v květnu 2017 představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky.

Ladislav Hagara | Komentářů: 15
30.5. 01:00 | Nová verze

Po více než pěti měsících od vydání verze 3.11.0 byla vydána nová stabilní verze 3.12.0, tj. první z nové řady 3.12, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Z novinek lze zmínit počáteční podporu architektury mips64 (big endian) a programovacího jazyka D.

Ladislav Hagara | Komentářů: 0
29.5. 23:00 | Komunita

Coffee Run je další krátký open source film od Blender Animation Studia. Vše o filmu na Blender Cloudu.

Ladislav Hagara | Komentářů: 7
29.5. 16:33 | Nová verze

Byla vydána nová verze 2020.06.01 distribuce BlackArch Linux (Wikipedie). Jedná se o distribuci založenou na Arch Linuxu zaměřenou na penetrační testování a výzkum počítačové bezpečnosti. Z novinek lze zmínit přes 150 nových nástrojů. Aktuálně jich je 2553.

Ladislav Hagara | Komentářů: 0
29.5. 14:11 | Komunita

V dubnu loňského roku získal multiplatformní open source herní engine Godot (Wikipedie) 50 tisíc dolarů z programu Mozilla Open Source Support (MOSS) Mission Partners na portaci Godot Editoru na webové technologie (HTML5 a WebAssembly), vylepšení podpory WebRTC, přidání podpory WebSocket a vytvoření 3D modelů pro nová dema. Fabio Alessandrelli dnes přestavil jeden z výsledků: Godot Editor běžící ve webovém prohlížeči.

Ladislav Hagara | Komentářů: 0
Používáte některé open-source řešení [protokol] pro šifrovaný instant messaging?
 (53%)
 (6%)
 (3%)
 (9%)
 (3%)
 (6%)
 (16%)
 (16%)
Celkem 32 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: 569×
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.