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 14:22 | IT novinky

    Herní studio Hangar 13 vydalo novou Mafii. Mafia: Domovina je zasazena do krutého sicilského podsvětí na začátku 20. století. Na ProtonDB je zatím bez záznamu.

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

    Operátor O2 má opět problémy. Jako omluvu za pondělní zhoršenou dostupnost služeb dal všem zákazníkům poukaz v hodnotě 300 Kč na nákup telefonu nebo příslušenství.

    Ladislav Hagara | Komentářů: 4
    dnes 05:55 | IT novinky

    Společnost OpenAI představila GPT-5 (YouTube).

    Ladislav Hagara | Komentářů: 0
    dnes 05:00 | Nová verze

    Byla vydána (𝕏) červencová aktualizace aneb nová verze 1.103 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.103 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 7
    včera 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | IT novinky

    Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.

    Ladislav Hagara | Komentářů: 4
    včera 04:55 | Nová verze

    Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    6.8. 16:33 | Nová verze

    Byla vydána nová verze 1.54.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Jan Václav.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (44%)
     (22%)
     (4%)
     (6%)
     (3%)
     (1%)
     (1%)
     (19%)
    Celkem 296 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: mysql efektivny insert/update 50 000 riadkov

    3.5.2012 14:43 adrinko | skóre: 22
    mysql efektivny insert/update 50 000 riadkov
    Přečteno: 547×
    Ahojte, na insert pouzivam nieco taketo, co mi vlozi cca 50000 zaznamov za krasnych 6 sekund:
    $sql = array();  
    foreach ($reports as $node) 
    {     
      $i = $node->getAttribute('i');
      $t = $node->getAttribute('t'); 
      $sql[] = '("'.$i.'",'.$t.'")'; 
    } 
    dibi::query('INSERT INTO [tabulka] (i, t) VALUES '.implode(',', $sql));
    
    Potreboval by som ale skript modifikovat tak, aby mi 50000 udajov najprv porovnal, ci sa uz nenachadza podla i v databaze, ak sa nachadza, tak by ho mal updatovat a ak sa nenachadza, tak by ho mal insertovat. Poradite prosim efektivny skript na toto? (mal by to zvladnut za par sekund) Vdaka vopred.

    Řešení dotazu:


    Odpovědi

    3.5.2012 15:14 NN
    Rozbalit Rozbalit vše Re: mysql efektivny insert/update 50 000 riadkov
    Pouzit UPDATE s podminkou, misto INSERT ?

    NN
    Tarmaq avatar 3.5.2012 15:24 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: mysql efektivny insert/update 50 000 riadkov
    udelej si neco jako:
    INSERT INTO tabulka (i, t)
    SELECT hodnota1a, hodnota1b UNION
    SELECT hodnota2a, hodnota2b
    EXCEPT
    SELECT i, t
    FROM tabulka
    ;
    
    nejak tusim ze to asi MySQL neumi, tak snad te to aspon nakopne a zacnes googlit relevantni data
    Don't panic!
    rADOn avatar 3.5.2012 16:05 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: mysql efektivny insert/update 50 000 riadkov
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    6.5.2012 10:52 Jirka
    Rozbalit Rozbalit vše Re: mysql efektivny insert/update 50 000 riadkov
    Na ten REPLACE pozor. Interné se provádí tak, že případný duplicitní záznam nejprve smaže a následně vytvoří nový.

    Pokud používáte integritní omezení na cizí klíče s nastavením ON DELETE CASCADE nebo ON DELETE SET NULL můžete si nevědomky smazat nebo vynulovat záznamy v jiných tabulkách.
    4.5.2012 11:59 Ivan
    Rozbalit Rozbalit vše Re: mysql efektivny insert/update 50 000 riadkov
    Tvuj problem se jmenuje UPSERT (update a insert dohromady). Ve standartnim SQL se to resi pomoci prikazu MERGE.

    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.