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 13:55 | Nová verze

Byla vydána verze 3.32 poštovního klienta Geary (Wikipedie). Změněno bylo číslování verzí. Předchozí verze byla 0.13. Nově bude číslování verzí stejné jako u GNOME.

Ladislav Hagara | Komentářů: 0
dnes 01:33 | Nová verze

Byla vydána nová major verze 4 průběžně aktualizované (rolling release) linuxové distribuce Solus (Wikipedie). Přehled novinek i s náhledy v příspěvku na blogu. Solus 4 je ke stažení v edicích Budgie, GNOME a MATE. Solus používá správce balíčku eopkg. Dotazy a odpovědi v novém diskusním fóru.

Ladislav Hagara | Komentářů: 0
včera 22:11 | Zajímavý software

Brian Linkletter se na svém blogu věnuje open source síťovým simulátorům. V nejnovějším příspěvku představuje open source síťový emulátor vrnetlab (VR Network Lab). Ten k běhu jednotlivých routerů používá Docker.

Ladislav Hagara | Komentářů: 0
včera 02:22 | Humor

Společnost SUSE natočila a na YouTube zveřejnila nový videoklip: Walk Like A Chameleon - SUSE Music Parody.

Ladislav Hagara | Komentářů: 17
včera 00:11 | Nová verze

Byla vydána verze 0.71 populárního telnet a ssh klienta PuTTY. Podrobnosti v přehledu změn. Řešeno je také několik bezpečnostních chyb. Nalezení většiny z nich bylo sponzorováno Evropskou komisí.

Ladislav Hagara | Komentářů: 0
15.3. 22:44 | Nová verze

V rámci projektu OpenRA je vyvíjen svobodný engine pro starší strategické hry Command & Conquer (nyní jsou freeware) a Dune 2000. Vydání 20190314 pokrývá změny za posledního půl roku: vylepšené chování jednotek, přepis kódu pro AI a celkem 9 nových misí pro jednoho hráče.

Fluttershy, yay! | Komentářů: 2
15.3. 21:33 | Nová verze

Po půl roce vývoje od vydání verze 1.14.0 byla vydána nová verze 1.16.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se na svých blozích věnují Ľubomír Rintel a Thomas Haller. Zdůrazněna je podpora WireGuardu.

Ladislav Hagara | Komentářů: 0
15.3. 14:55 | Nová verze

Po deseti měsících vývoje od vydání verze 3.1 byla vydána nová stabilní verze 3.2 proprietárního multiplatformního editoru textových souborů a zdrojových kódů Sublime Text (Wikipedie). Přehled novinek v příspěvku na blogu. Sublime Text je ke stažení a k vyzkoušení zdarma. Pro další používání je nutná licence v ceně 80 dolarů. Vývojáři editoru Sublime Text nedávno představili svého git klienta Sublime Merge. Ten je také ke stažení a k vyzkoušení zdarma. Licence stojí 99 dolarů.

Ladislav Hagara | Komentářů: 0
14.3. 19:33 | Zajímavý software

Příspěvek na blogu Giant Pockets představuje emulátor Box86 umožňující spouštět aplikace pro x86 na architektuře ARM. Diskuse na stránkách open source kapesního počítače a herní konzole Pyra.

Ladislav Hagara | Komentářů: 14
14.3. 18:33 | Nová verze

Po více než roce vývoje od vydání verze 3.0 byla vydána verze 3.1 multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v oficiálním oznámení nebo na YouTube.

Ladislav Hagara | Komentářů: 1
Kolik balíčků (v tisících) máte nainstalovaných na svém systému?
 (4%)
 (13%)
 (34%)
 (30%)
 (20%)
 (4%)
 (2%)
 (2%)
 (3%)
Celkem 199 hlasů
 Komentářů: 16, poslední 14.3. 20:04
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: 338×
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.