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 19:33 | Pozvánky

    OpenSSL Corporation zve na den otevřených dveří ve středu 20. srpna v Brně a konferenci OpenSSL od 7. do 9. října v Praze.

    Ladislav Hagara | Komentářů: 0
    dnes 19:22 | Komunita

    Konference LinuxDays 2025 proběhne o víkendu 4. a 5. října v Praze. Konference OpenAlt 2025 o víkendu 1. a 2. listopadu v Brně. Blíží se konec přihlašování přednášek. Přihlaste svou přednášku (LinuxDays do 31. srpna a OpenAlt do 3. října) nebo doporučte konference známým.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | IT novinky

    Raspberry Pi Touch Display 2 je nově vedle 7palcové k dispozici také v 5palcové variantě. Rozlišení stejné 720 × 1280 pixelů. Cena 40 dolarů.

    Ladislav Hagara | Komentářů: 1
    dnes 04:44 | IT novinky

    Telnet a ssh klient PuTTY postupně přechází na novou doménu putty.software.

    Ladislav Hagara | Komentářů: 3
    16.8. 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 16
    15.8. 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 10
    15.8. 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 4
    15.8. 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 13
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 32
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (50%)
     (17%)
     (17%)
     (0%)
     (17%)
     (0%)
    Celkem 6 hlasů
     Komentářů: 0
    Rozcestník

    Dotaz: Vlastná funkcia v Oracle

    28.6.2017 13:56 pv7
    Vlastná funkcia v Oracle
    Přečteno: 1485×
    Nie som databázový admin ani vývojár napriek tomu potrebujem vyriešiť nasledovný problém s Oracle. Mám SQL dopyt, kde hodnoty v jednom stĺpci sa získavajú ako výsledok funkcie. Definíciu funkcie mám, aj som ju cez SQLplus definoval, ale neviem, či správne, lebo pri volaní SQL príkazu to skončí chybou akurát kvôli funkcii. Volanie samotnej funkcie taktiež nefunguje.
    CREATE OR REPLACE FUNCTION fnz( ... ) RETURN VARCHAR2
         BEGIN
           ...
           RETURN ...;
         END;
         /
    
    SQL> select object_name,procedure_name,object_type from all_procedures where object_name like '%fnz%';
    
    OBJECT_NAME  PROCEDURE_NAME  OBJECT_TYPE
    ------------ --------------- -----------
    fnz                           FUNCTION
    
    SQL> call fnz('...')
    
    ERROR at line 1:
    ORA-06576: not a valid function or procedure name
    

    Odpovědi

    28.6.2017 15:10 jekub
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    To se mi nezdá, pokud byste funkci vyvářel jak píšete, identifikátor v selectu by byl velkými. Nepoužil jste náhodou uvozovky?

    Otestujte jestli je fce validní
    select object_name,object_type,status from user_objects where lower(object_name)='fnz'
    Pokud ne, tak je chyba ve funkci. V tom případě jste při vytváření dostal nějaké chybové hlášení.

    28.6.2017 15:13 jekub
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    a chybí tam ...return varchar2 IS

    To co píštee by neprošlo...
    28.6.2017 15:20 jekub
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    jo a k tomu call, to nebude to pravé. Pro procedury "exec", pro funkce "select (from dual)"
    28.6.2017 19:14 pv7
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    Funkcia pri definovaní bola úspešne vytvorená (vytvorená pod SYSDBA). Objekt je validný. Vami spomínané chyby vznikli pri anonymizácii pred postnutím sem na fórum.

    Keď spustím select fnz('aaa bbb') from dual; tak dostanem chyby
    ERROR v riadku 1:
    ORA-00900: neplatny prikaz SQL
    ORA-06512: na "SYS.FNZ", line 9
    ORA-06512: na line 1
    
    Skúšal som to pod používateľom abc (má GRANT EXECUTE ANY PROCEDURE) a tiež pod SYSDBA.
    28.6.2017 21:22 jekub
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    Není dobrý nápad*) dělat ZMĚNY ve schematu SYS (a dalších systémových). Použijte buď testovacího uživatele (pokud existuje), nebo vždy toho abc.

    K chybě - nespouští se na řádku 9 dynamicky sql dotaz (exec immediate, dbms_sql)?

    *) kdyby existovala systémová fce fnz, sundal byste databázi
    19.7.2017 15:17 rich
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    a jak by databazi tou funkci/procedurou sundal?
    23.8.2017 15:49 BigBoss
    Rozbalit Rozbalit vše Re: Vlastná funkcia v Oracle
    Jak níže pověděl kolega, pod uživatelem SYS funkce atd možná instalujete, ale nemůžete je dávat do SYS schématu - miliarda důvodů proč ne!!! .před název funkce si dejte název jiného schématu(uživatele), kde tu funkci nainstalujte. Za tím tečku a název funkce, tedy např honza.funkce(...) to nainstaluje do schématu honza.

    Pak když ji nainstalujete, dáte ji public synonymum, pokud ji chcete spouštět z jiného schématu, a k tomu grant pro daného uživatele, který to má spouštět.

    Pokud bude problém, podívejte se, zda-li je funkce validní objekt a spusťte ji například ze schématu, kde jste ji nainstaloval.

    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.