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

    Byl vydán Mozilla Firefox 118.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Vypíchnout je nutno automatický lokální strojový překlad webových stránek. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 118 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 3
    včera 12:55 | Nová verze

    Byla vydána nová major verze 15.0.0 softwaru OCRmyPDF pro přidávání textové vrstvy k naskenovaným PDF dokumentům (PDF/A). Přehled novinek v poznámkách k vydání. OCRmyPDF využívá pro optické rozpoznávání znaků (OCR) engine Tesseract.

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

    Karel Matějka zveřejnil druhé demo své chystané hry Bzzzt. Kromě verze pro Windows a macOS je dostupná i verze pro Linux. Plná verze hry má vyjít zanedlouho.

    Ondřej J | Komentářů: 3
    25.9. 20:33 | IT novinky

    Noví Bulánci byli oficiálně vydáni. V roce 2021 bylo na Startovači na podporu vývoje této hry vybráno 7,3 miliónů Kč. Hra je zatím určena jenom pro Windows, díky Protonu ale běží také na Linuxu.

    Ladislav Hagara | Komentářů: 8
    25.9. 14:55 | IT novinky

    ChatGPT může vidět, slyšet a mluvit.

    Ladislav Hagara | Komentářů: 4
    25.9. 14:33 | Zajímavý software

    Upscaler je open source nástroj pro zvýšení rozlišení a vylepšení obrázků pomocí AI. Vývoj probíhá na GitLabu. Instalovat lze také z Flathubu. Stejně jako Upscayl je Upscaler postaven nad Real-ESRGAN.

    Ladislav Hagara | Komentářů: 1
    25.9. 12:11 | Nová verze

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.20.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

    Ladislav Hagara | Komentářů: 0
    25.9. 11:55 | Komunita

    V Dublinu o víkendu proběhla dvanáctá iterace multimediální konference Video Dev Days, kterou pravidelně pořádá nezisková organizace VideoLAN. Záznamy přednášek z prvního a druhého dne jsou dostupné na YouTube.

    elenril | Komentářů: 0
    24.9. 20:44 | Nová verze

    LibrePCB, tj. svobodný multiplatformní softwarový nástroj pro návrh desek plošných spojů (PCB), dospěl po pěti letech vývoje do verze 1.0.0. Přehled novinek v příspěvku na blogu a v aktualizované dokumentaci. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GPLv3.

    Ladislav Hagara | Komentářů: 0
    23.9. 16:55 | IT novinky

    Facebook má nové logo. Poznáte rozdíl?

    Ladislav Hagara | Komentářů: 8
    Knihy s linuxovou tematikou
     (19%)
     (15%)
     (51%)
     (27%)
    Celkem 277 hlasů
     Komentářů: 11, poslední 17.9. 19:19
    Rozcestník

    Dotaz: Postgresql a prohledavani vice tabulek

    26.8.2005 02:32 JFK
    Postgresql a prohledavani vice tabulek
    Přečteno: 85×
    Dobry den, jsem uplny zacatecnik. Prosim o radu jakym zpusobem se daji prohledavat sloupce the_geom ve vsechny tabulkach.

    Vytvoril jsem si funkci, ktera vrati pole s nazvy tabulek a potom jednotlive polozky (nazvy tab.) predavam nize uvedene funkci isinside(), nicmene tato funkce mi vraci chybu:

    ERROR: syntax error at or near "$1" at character 132

    Pokud misto $1 napisu primo nazev tabulky, tak fce pracuje korektne. Zkousel jsem vytvaret obdobnou fci i v PLPGSQL, ale mam stejny problem. Nejsis to bude naka uplna blbost, ale opravdu me nenapada kde je chyba.

    Dekuji za radu.

    CREATE OR REPLACE FUNCTION isinside(varchar) RETURNS varchar AS $$ SELECT astext(the_geom) FROM $1 WHERE Transform(the_geom,102065) && GeometryFromText('POLYGON ((-479167.183908046 -1100294.4683908047, -478249.625 -1100355.375, -478203.96875 -1101317.5, -479295.1875 -1101235.375, -479148.7787356322 -1100300.603448276, -479167.183908046 -1100294.4683908047))',102065); $$ LANGUAGE SQL;

    Odpovědi

    28.8.2005 20:52 JFK
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Tak se to jeste pokusim zjednodusit, v podstate mi jde o to, jak mam funkci predat nazev tabulky a na tu se pak dotazovat. Uvadim uplne jednoduchy priklad, ten predchozi byl trochu "zbesily" a chapu, ze si rika vylozene o to, se tim nezabyvat.
    CREATE OR REPLACE FUNCTION pokus(varchar) RETURNS int4 AS '
    DECLARE
    v ALIAS FOR $1;
    BEGIN
    SELECT AsText(the_geom) FROM v;
    RETURNS 0;
    END;
    ' LANGUAGE plpgsql;
    
    SELECT pokus('b'); 
    ERROR:  syntax error at or near "$1" at character 32
    QUERY:  SELECT  Astext(the_geom) FROM  $1
    CONTEXT:  PL/pgSQL function "pokus" line 4 at SQL statement
    LINE 1: SELECT  Astext(the_geom) FROM  $1
                                           ^
    Budu vdecny za jakykoliv podnet. Predem dekuji.
    28.8.2005 20:58 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Uzamknúť, zmazať, skúsiť inde. :-)
    29.8.2005 11:22 JFK
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Dik za tip, ale tam se ta diskuse nezda prilis ziva.... . :-) Pokud nekdo tusi co s tim, tak bych byl rad za jakoukoliv radu.

    Dekuju
    29.8.2005 14:30 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Tá diskusia živá je, ale je tam iba asi týždeň, takže si ešte návštevníci na ňu nezvykli. A administrátori zatiaľ ignorujú výzvy pridať ju viditeľne do menu či dokonca integrovať fórum do hlavnej stránky.
    29.8.2005 19:47 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Tak zkuste Interfórum, aspoň to tam nebude pořád jen o MySQL… :-)
    29.8.2005 16:33 Pavel 'lingeek' Szalbot | skóre: 54 | Třinec
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Přečti si 'Executing dynamic commands' (kap. 37.6.4.) v dokumentaci. Pokud by ses nechtěl obtěžovat (což asi nebudeš), tak:
    CREATE OR REPLACE FUNCTION pokus(varchar) RETURNS integer AS '
            DECLARE
                    v ALIAS FOR $1;
                    x INTEGER;
            BEGIN
                    EXECUTE ''SELECT id INTO x FROM '' || v || '' LIMIT 1'';
            RETURN x;
            END;
    ' LANGUAGE plpgsql;
    
    Pozor! SELECT INTO v PostgreSQL 7.4.8 ještě není implementováno. Lepší by asi bylo použít nějaký cyklus (v tomto případě)... RTFM a take it easy;-)
    Math, as Barbie says, is hard.
    29.8.2005 16:58 Bubak
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Navic takhle dochazi pri kazdem volani znovu k parsingu sql prikazu.
    29.8.2005 17:40 JFK
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Dekuji moc za radu ... . Mam PostgreSQL 8.0.2 a pri volani teto funkce:
    CREATE OR REPLACE FUNCTION mujpokus(varchar) RETURNS varchar AS '
            DECLARE
                    v ALIAS FOR $1;
                    x INTEGER;
            BEGIN
                    EXECUTE ''SELECT AsText(the_geom) INTO x FROM '' || v || '' LIMIT 1'';
            RETURN x;
            END;
    ' LANGUAGE plpgsql;
    mi to hodi tuto hlasku:
    kam038=# SELECT mujpokus('b');
    ERROR:  EXECUTE of SELECT ... INTO is not implemented yet
    CONTEXT:  PL/pgSQL function "mujpokus" line 5 at execute statement
    Tak to vypada ze to neimplementovali ani sem :-(

    Ale dik za radu, zajimalo by me, jestli je mozny nak ziskat vystup z ty funkce spusteny v EXECUTE. Zkousel jsem FOUND bez toho SELECT INTO a nic.

    Sem si myslel, ze to je uplne kravina resitelna bez problemu ale vypada to, ze tenhle jazyk ma pomerne velky omezeni. Nevite v cem by se podobna vec mohla napsat pokud mozno bez vetsich problemu?
    29.8.2005 18:08 Pavel 'lingeek' Szalbot | skóre: 54 | Třinec
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Příklad, který jsem ti tu hodil, stejně dělá něco jiného, než nejspíš chceš. Cyklus FOR ti pomůže - SELECT INTO x id FROM tbl (což uloží id do proměnné) není SQL dotaz;-). Dokumentace je vážně dobré místo, kde začít.
    Math, as Barbie says, is hard.
    29.8.2005 19:29 JFK
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    Mojim cilem je vytvorit funkci, ktera mi vrati seznam tabulek ve kterych jsou nake GIS prvky obsazene v mnou definovanem obdelniku (ziskam kliknutim na mapu-takze ho taky budu muset predavat). For cyklus mam v jine funkci ze ktere volam tuhle. Chci ji predat nazev tabulky a nechat ji provest dotaz. Ona mi jen vrati jestli tam naky prvek je, nebo ne. Ten EXECUTE je to co potrebuju, jen nevim jak zjistit nakou navratovou hodnotu, protoze jak jsem psal, SELECT INTO neni "zatim" implementovan. Je mi jedno kolik tech prvku tam v ty tabulce je nebo jaky to jsou, jen potrebuju vedet jestli tam vubec nakej je. Tohle jede pokud se dotazuju na konkretni tabulku, ale pokud predavam nazev tabulky jako parametr funkce, tak to nefici. S tim EXECUTE to jde, ale zas nejde zjistit navratova hodnota. Respektive nevim jak. V dokumentaci jsem nic ani vzdalene podobnyho nenasel.

    Dekuju za vase rady.
    29.8.2005 19:49 Pavel 'lingeek' Szalbot | skóre: 54 | Třinec
    Rozbalit Rozbalit vše Re: Postgresql a prohledavani vice tabulek
    viz kap. 37.7.4 (a vubec 37.7.*):
    FOR record_or_row IN EXECUTE text_expression LOOP 
        statements
    END LOOP;
    
    Proto ten FOR...
    Math, as Barbie says, is hard.

    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.