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 21:33 | Nová verze

    Desktopové prostředí Budgie bylo vydáno ve verzi 10.10. Dokončena byla migrace z X11 na Wayland. Budgie 10 vstupuje do režimu údržby. Vývoj se přesouvá k Budgie 11. Dlouho se řešilo, v čem bude nové Budgie napsáno. Budgie 10 je postaveno nad GTK 3. Přemýšlelo se také nad přepsáním z GTK do EFL. Budgie 11 bude nakonec postaveno nad Qt 6.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Humor

    OpenChaos.dev je 'samovolně se vyvíjející open source projekt' s nedefinovaným cílem. Každý týden mohou lidé hlasovat o návrzích (pull requestech), přičemž vítězný návrh se integruje do kódu projektu (repozitář na GitHubu). Hlasováním je možné změnit téměř vše, včetně tohoto pravidla. Hlasování končí vždy v neděli v 9:00 UTC.

    NUKE GAZA! 🎆 | Komentářů: 2
    včera 03:00 | Nová verze

    Byl vydán Debian 13.3, tj. třetí opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.13, tj. třináctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    10.1. 03:00 | Komunita

    Na stránkách Evropské komise, na portálu Podělte se o svůj názor, se lze do 3. února podělit o názor k iniciativě Evropské otevřené digitální ekosystémy řešící přístup EU k otevřenému softwaru.

    Ladislav Hagara | Komentářů: 6
    9.1. 19:44 | Zajímavý software

    Společnost Kagi stojící za stejnojmenným placeným vyhledávačem vydala (𝕏) alfa verzi linuxové verze (flatpak) svého proprietárního webového prohlížeče Orion.

    Ladislav Hagara | Komentářů: 5
    9.1. 19:11 | IT novinky

    Firma Bose se po tlaku uživatelů rozhodla, že otevře API svých chytrých reproduktorů SoundTouch, což umožní pokračovat v jejich používání i po plánovaném ukončení podpory v letošním roce. Pro ovládání také bude stále možné využívat oficiální aplikaci, ale už pouze lokálně bez cloudových služeb. Dokumentace API dostupná zde (soubor PDF).

    NUKE GAZA! 🎆 | Komentářů: 2
    9.1. 14:22 | Zajímavý článek

    Jiří Eischmann se v příspěvku na svém blogu rozepsal o open source AdGuard Home jako domácí ochraně nejen před reklamou. Adguard Home není plnohodnotným DNS resolverem, funguje jako DNS forwarder s možností filtrování. To znamená, že když přijme DNS dotaz, sám na něj neodpoví, ale přepošle ho na vybraný DNS server a odpovědi zpracovává a filtruje dle nastavených pravidel a následně posílá zpět klientům. Dá se tedy používat k blokování reklamy a škodlivých stránek a k rodičovské kontrole na úrovni DNS.

    Ladislav Hagara | Komentářů: 7
    9.1. 03:33 | Zajímavý software

    AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.

    Ladislav Hagara | Komentářů: 1
    9.1. 00:11 | Nová verze

    Byla vydána prosincová aktualizace aneb nová verze 1.108 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.108 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.1. 20:44 | IT novinky

    Na lasvegaském veletrhu elektroniky CES byl předveden prototyp notebooku chlazeného pomocí plazmových aktuátorů (DBD). Ačkoliv se nejedná o první nápad svého druhu, nepochybně to je první ukázka praktického použití tohoto způsobu chlazení v běžné elektronice. Co činí plazmové chladící akční členy technologickou výzvou je především vysoká produkce jedovatého ozonu, tu se prý podařilo firmě YPlasma zredukovat dielektrickou

    … více »
    NUKE GAZA! 🎆 | Komentářů: 15
    Které desktopové prostředí na Linuxu používáte?
     (8%)
     (4%)
     (0%)
     (9%)
     (20%)
     (3%)
     (5%)
     (3%)
     (10%)
     (50%)
    Celkem 373 hlasů
     Komentářů: 8, poslední 10.1. 23:18
    Rozcestník

    Dotaz: SQLite zpomaluje během INSERT OR IGNORE

    21.5.2020 07:03 Aleš Nehyba | skóre: 1
    SQLite zpomaluje během INSERT OR IGNORE
    Přečteno: 1171×
    ahoj,

    Při vkládání velkého množství záznamů do SQLite pomocí příkazu INSERT OR IGNORE pozoruji výrazné zpomalení. Data vkládám přes python z csv souborů. Mám desítky souborů o velikosti cca 300 MB a každý obsahuje statisíce až milion záznamů - textové popisky definující význam a k nim přiřazená číselné hodnoty. Python vytváří několik číselníků, do kterých se ukládají ty popisky, aby se šetřilo místo, protože ty jsou hodně duplicitní.

    Zpracování prvních takových souborů trvá pár desítek vteřin/několik minut na každý soubor. Postupně se čas zpracování souboru prodlužuje a dosahuje i desítek minut/pár hodin. Nějak významně nepomohlo ani vypnutí indexování během vkládání. Transakce používám.

    K datům bude přistupovat pouze jeden program běžící lokálně. Proto jsem volil sqlite. To zpomalování při vkládání mě ale nutí zeptat se, jestli by na tom jiné databáze nebyly lépe?


    Řešení dotazu:


    Odpovědi

    21.5.2020 12:10 debian+
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Urcite lepsie.

    Mas na vyber SQL alebo NoSQL databazy. SQLite pri ukladany zmeny potrebuje ulozit databazu ako SQL dotaz (RAW -> SQL), co pri tom mnozstve chce cas a blokuje pracu s DB.
    21.5.2020 12:46 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Ako vzdy, aj tu plati, ze DB engine treba vyberat podla potrieb aplikacie. Takze tazko povedat, ako by na tom boli ine databazy.

    Nevieme, ako vyzeraju data. Mohol by tu pomoct bulk load CSV do docasnej tabulky v sqlite a nasledny podmieneny INSERT INTO trvale SELECT FROM docasne WHERE NOT IN/NOT EXISTS (trvale). Toto sa potom da urobit aj z CLI, resp. v bashi cez sqlite3 klienta.

    Nepozname tvoju aplikaciu - a v akej forme robis dotazy. Python je dost pomaly a ten bottleneck mozes mat v nejakom tvojom foreach. Skus si spravit profiling, nech vidis, kde ten program travi cas.

    Nevieme, ci potrebujes mat data perzistentne. Subor so Sqlite databazou je mozne nacitat aj do RAM a pouzit ju ako in-memory DB. Spatne ulozenie do suboru vsak bolo par rokov dozadu trochu zlozitejsie, ale islo aj to. Ak potrebujes len key-value, potom by mozno taky Redis bol pre teba vhodnejsi.
    21.5.2020 18:09 Aleš Nehyba | skóre: 1
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE

    Díky za tip. Zkusím tu dočasnou tabulku.

    Data převádím do databáze pro trvalé uložení. Vyhledávání v původních csv souborech celkem trvá. Dotaz do SQL je mnohonásobně rychlejší. Těch dotazů může být v dávce několik tisíc, výsledkem každého je několik desítek řádků pro další zpracování. Zpočátku to vypadalo, že databáze je řešení. Ale s prodlužujícím se časem zpracování insertů už to tak růžové není. Už je skoro jedno, jestli čekat hodiny na přípravu dat pro sql dotazy, nebo hodiny na zpracování dotazů do csv.

    Velikost databáze je dnes cca 12 GB. Za rok naroste cca o 1 GB, to je asi 6 mio záznamů.

    28.5.2020 11:33 Aleš Nehyba | skóre: 1
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Tak ta úprava INSERT pomohla. Díky.
    21.5.2020 12:50 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Bez znalostí požadavků na systém (typy dotazů) se dá těžko odpovědět. Plnění SQLite skutečně trvá déle a možná bude stát za to vydržet i několikadenní plnění, protože čtení bývá rychlé.

    Ovšem pokud to má být KVS, tak se dá najít pár vhodnějších databází. Je možné i využití NoSQL.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    21.5.2020 14:05 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Na tohle by se dala využít DB4, která je pro podobné účely fakt rychlá. Zkoušel jsem i Tokyo Cabinet, který také podával zajímavé výkony.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    21.5.2020 20:32 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Bulk insert se tu řeší v diskuzích pravidelně (pro různé databáze). Každá databáze se chová jinak a řada databází umí nacpat csv do tabulky přímým importem - je to mnohonásobně rychlejší než normální insert (i multi-insert, kdy se vkládá více záznamů jediným dotazem). Některé databáze umí mít jako storage i csv, takže by pak stálo za to zkusit načíst csv takto a pak selectem překopírovat do cílové tabulky. Zkusit jak je na tom databáze s výkonem v režimu in-memory. Při importu koukat na obsazení RAM, vytížení CPU a vytížení IO. Pokud jde o data ze sensorů existují specializované time-series databáze, které řeší některá specifika efektivněji.

    Nakonec stojí za zvážení změna workflow, zda by nešlo vkládat záznamy do databáze bez csv mezikroku.

    Pokud to chcete řešit podrobněji, chce to vidět ten python script a vzorek dat.
    -- OldFrog
    21.5.2020 20:42 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    PS: Ruční tvorbě číselníků by se šlo asi vyhnout, například by šlo popisky uložit do jiné 1:1 tabulky a na tu tabulku nastavit vhodný typ úložiště (s kompresí) nebo prostě jen nastavit jiný vhodnější typ sloupce (trigramy). To by odvedlo stejnou práci - a oproti skriptu by to bylo určitě efektivnější. Jsem celkově přesvědčen, že vhodné řešení může přinést řádové urychlení.
    -- OldFrog
    23.5.2020 21:47 Tom K | skóre: 22
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    sqlite3 má jako vlastnost, že při určitém počtu záznamů začne výrazně zpomalovat insert. Ten počet je někde okolo milionu řádků. Souvisí to s implicitním indexem a UNIQUE sloupci, které se chovají jako indexy. Na jednom projektu, kde jsem potřeboval řádově desítky milionů řádků jsem to řešil rozdělením do samostatných databází, které jsem následně spojil (bylo jich 512).
    Při spojování je důležité klíčové slovo WITHOUT ROWID.
    Zajímavý odkaz je tady: https://stackoverflow.com/questions/15778716/sqlite-insert-speed-slows-as-number-of-records-increases-due-to-an-index/15809806
    echo -n "u48" | sha1sum | head -c3; echo
    24.5.2020 21:18 Aleš Nehyba | skóre: 1
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Díky. Ve dvou největších tabulkách mám 25 mio a 60 mio řádků. Zkusím ta data rozdělit podle let.
    24.5.2020 23:11 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: SQLite zpomaluje během INSERT OR IGNORE
    Však už to máš rozděleno. Z každého vstupního souboru uděláš jednu databázi a následně je spojíš do jedné.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

    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.