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

    Ubuntu pro testování nových verzí vydává měsíční snapshoty. Dnes vyšel 1. snapshot Ubuntu 26.04 LTS (Resolute Raccoon).

    Ladislav Hagara | Komentářů: 0
    dnes 14:33 | IT novinky

    Zástupci členských států EU se včera shodli na návrhu, který má bojovat proti šíření materiálů na internetu zobrazujících sexuální zneužívání dětí. Nařízení známé pod zkratkou CSAM a přezdívané chat control mělo množství kritiků a dlouho nebyla pro jeho schválení dostatečná podpora. Pro schválení byla potřeba kvalifikovaná většina a dánské předsednictví v Radě EU se snažilo dosáhnout kompromisu. Návrh nakonec po dlouhých týdnech

    … více »
    Ladislav Hagara | Komentářů: 4
    dnes 12:22 | Zajímavý software

    Britské herní studio Facepunch stojící za počítačovými hrami Garry's Mod a Rust uvolnilo svůj herní engine s&box (Wikipedie) jako open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Herní engine s&box je postavený nad proprietárním herním enginem Source 2 od společnosti Valve.

    Ladislav Hagara | Komentářů: 1
    dnes 04:55 | Komunita

    Vývoj programovacího jazyka Zig byl přesunut z GitHubu na Codeberg. Sponzoring na Every.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | Komunita

    Stejně jako GNOME i KDE Plasma končí s X11. KDE Plasma 6.8 poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 1
    včera 14:55 | IT novinky

    Poslanci Evropského parlamentu dnes vyzvali k výraznému zvýšení ochrany nezletilých na internetu, včetně zákazu vstupu na sociální sítě pro osoby mladší 16 let. Legislativně nezávazná zpráva, kterou dnes odsouhlasil Evropský parlament poměrem 493 hlasů pro ku 92 proti, kromě zavedení věkové hranice 16 let pro využívání sociálních sítí, platforem pro sdílení videí či společníků s umělou inteligencí (AI) vyzývá také k zákazu … více »

    Ladislav Hagara | Komentářů: 44
    včera 14:11 | Humor

    Doom v KiCadu nebo na osciloskopu? Žádný problém: KiDoom: Running DOOM on PCB Traces a ScopeDoom: DOOM on an Oscilloscope via Sound Card.

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

    Po AlmaLinuxu byl v nové stabilní verzi 10.1 vydán také Rocky Linux. Přehled novinek v poznámkách k vydání.

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

    Open source reimplementace počítačových her Tomb Raider I a Tomb Raider II spolu s dalšími vylepšeními a opravami chyb TRX byla vydána ve verzi 1.0. Jedná se o sloučení projektů / enginů TR1X a TR2X do jednoho TRX. Videoukázka na YouTube.

    Ladislav Hagara | Komentářů: 1
    25.11. 17:00 | IT novinky

    Společnost Seznam.cz spouští konverzační nástroj založený na umělé inteligenci Seznam Asistent. Asistent využívá vlastní jazykový model SeLLMa a dočasně i komerční modely od OpenAI provozované v evropských datacentrech prostřednictvím Microsoft Azure. Dlouhodobým cílem Seznamu je provozovat Asistenta výhradně na interních jazykových modelech a ve vlastních datových centrech.

    Ladislav Hagara | Komentářů: 8
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (47%)
     (19%)
     (18%)
     (22%)
     (15%)
     (23%)
     (16%)
     (18%)
    Celkem 410 hlasů
     Komentářů: 17, poslední 19.11. 21:57
    Rozcestník

    Dotaz: SQL dotaz

    11.1.2017 18:20 Hanyz
    SQL dotaz
    Přečteno: 1548×
    Ahoj, potřeboval bych jednu věc, ale úplně ji zjednoduším.

    Mám 2 tabulky. V první tabulce tab1 mám sloupce a1, a2, a3. Všechny sloupce jsou naplněny číselnými hodnotamy. Pak mám druhou tabulku tab2 se sloupci b1, b2, b3. Všechny sloupce jsou taktéž naplěnny číselnými hodnotamy. A teď bych potřeboval, aby sloupec a2 z tab1 byl přepsán (aktualizován) na hodnoty odpovídající sloupci b2 z tabulky tab2. Přičemž, aby to tam jen tak nenaházel, tak přepiš data jen tam, kde hodnoty sloupců a3 a b3 se sobě musí rovnat.

    Šlo by to nějak přes UPDATE? Děkuji

    Odpovědi

    11.1.2017 20:40 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: SQL dotaz
    Šlo. Detaily môžu záležať na konkrétnej databáze. Pred pár dňami som niečo také riešil a bol to "vopruz". Hlavne preto, že sa mi to kazili constrainty. Ale v princípe to ide.
    11.1.2017 20:42 Ivan2 | skóre: 5
    Rozbalit Rozbalit vše Re: SQL dotaz
    tohle?

    http://stackoverflow.com/questions/2446764/update-statement-with-inner-join-on-oracle#
    11.1.2017 20:45 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: SQL dotaz
    Především doporučuji zvolit lepší názvy tabulek a sloupců. Bude se s nimi mnohem lépe pracovat. Nad takovými hloupými názvy se mi ani nechce přemýšlet.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    11.1.2017 20:54 jekub
    Rozbalit Rozbalit vše Re: SQL dotaz
    typ db je tajny, tak kdyby nahodou
    update (
    select a2,b2
    from tab1
    inner join tab2 on a3=b3
    )
    set a2=b2
    
    12.1.2017 11:29 Štefan
    Rozbalit Rozbalit vše Re: SQL dotaz
    pro ms sql:
    update tab1
    set tab1.a2 = tab2.b2
    from tab1
    join tab2 on tab2.b3=tab1.a3
    
    3.2.2017 10:49 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: SQL dotaz
    sqlite, ktore nema klauzulu FROM v UPDATE:

    -- pre b2 NOT NULL a pocty zaznamov (zhruba) 1:1 v tab1:tab2; pri velkom tab2 s indexom na (b3,b2)
    UPDATE tab1
       SET a2 = COALESCE((
             SELECT tab2.b2
                FROM tab2
                WHERE tab2.b3 = tab1.a3
                LIMIT 1
             ), a2)
    ;

    -- resp. pre velke tab1 a male tab2; s indexom na (a3)
    UPDATE tab1
       SET a2 = (
             SELECT tab2.b2
                FROM tab2
                WHERE tab2.b3 = tab1.a3
                LIMIT 1
             )
       WHERE a3 IN (
             SELECT b3
                FROM tab2
             )
    ;
    -- resp. pre male tab1 a velke tab2; s indexom na (b3,b2)
    UPDATE tab1
       SET a2 = (
             SELECT tab2.b2
                FROM tab2
                WHERE tab2.b3 = tab1.a3
                LIMIT 1
             )
       WHERE EXISTS (
             SELECT 1
                FROM tab2
                WHERE b3 = a3
             )
    ;
    

    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.