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

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

    Ladislav Hagara | Komentářů: 2
    včera 21:00 | Zajímavý projekt

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 1
    včera 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 5
    6.2. 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 17
    6.2. 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 10
    6.2. 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    6.2. 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 26
    6.2. 11:11 | Nová verze

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

    Ladislav Hagara | Komentářů: 0
    6.2. 04:22 | Komunita

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 216. sraz, který proběhne v pátek 20. února od 18:00 v Red Hat Labu (místnost Q304) na Fakultě informačních technologií VUT v Brně na ulici Božetěchova 1/2. Tématem srazu bude komunitní komunikační síť MeshCore. Jindřich Skácel představí, co je to MeshCore, předvede nejrůznější klientské zařízení a ukáže, jak v praxi vypadá nasazení vlastního repeateru.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (26%)
     (3%)
     (4%)
     (2%)
     (12%)
     (29%)
    Celkem 802 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Postgresql vnořená funkce id sloupců

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