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 03:11 | Komunita

    Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.

    Ladislav Hagara | Komentářů: 0
    dnes 02:11 | Zajímavý článek

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

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

    OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzi 2.4.0.

    Ladislav Hagara | Komentářů: 0
    dnes 01:00 | IT novinky

    Kriminalisté z NCTEKK společně s českými i zahraničními kolegy objasnili mimořádně rozsáhlou trestnou činnost z oblasti kybernetické kriminality. V rámci operací OCTOPUS a CONNECT ukončili činnost čtyř call center na Ukrajině. V prvním případě se jednalo o podvodné investice, v případě druhém o podvodné telefonáty, při kterých se zločinci vydávali za policisty a pod legendou napadeného bankovního účtu okrádali své oběti o vysoké finanční částky.

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

    Na lepší pokrytí mobilním signálem a dostupnější mobilní internet se mohou těšit cestující v Pendolinech, railjetech a InterPanterech Českých drah. Konsorcium firem ČD - Telematika a.s. a Kontron Transportation s.r.o. dokončilo instalaci 5G opakovačů mobilního signálu do jednotek Pendolino a InterPanter. Tento krok navazuje na zavedení této technologie v jednotkách Railjet z letošního jara.

    Ladislav Hagara | Komentářů: 3
    včera 12:22 | Bezpečnostní upozornění

    Rozšíření webového prohlížeče Urban VPN Proxy a další rozšíření od stejného vydavatele (např. 1ClickVPN Proxy, Urban Browser Guard či Urban Ad Blocker) od července 2025 skrytě zachytávají a odesílají celé konverzace uživatelů s AI nástroji (včetně ChatGPT, Claude, Gemini, Copilot aj.), a to nezávisle na tom, zda je VPN aktivní. Sběr probíhá bez možnosti jej uživatelsky vypnout a zahrnuje plný obsah dotazů a odpovědí, metadata relací i

    … více »
    Ladislav Hagara | Komentářů: 5
    včera 05:22 | Zajímavý software

    QStudio, tj. nástroj pro práci s SQL podporující více než 30 databází (MySQL, PostgreSQL, DuckDB, QuestDB, kdb+, …), se stal s vydáním verze 5.0 open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí Apache 2.0.

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

    Byla vydána nová verze 259 správce systému a služeb systemd (Wikipedie, GitHub).

    Ladislav Hagara | Komentářů: 0
    včera 02:55 | Zajímavý článek

    Cloudflare Radar poskytuje aktuální informace o globálním internetovém provozu, útocích nebo trendech. Publikován byl celkový přehled za rok 2025. Globální internetový provoz vzrostl v roce 2025 o 19 %.

    Ladislav Hagara | Komentářů: 0
    17.12. 15:22 | IT novinky

    Správní rada americké mediální skupiny Warner Bros. Discovery (WBD) podle očekávání odmítla nepřátelskou nabídku na převzetí od firmy Paramount Skydance za 108,4 miliardy dolarů (2,25 bilionu Kč). Paramount podle ní neposkytl dostatečné finanční záruky. Akcionářům proto doporučuje nabídku od Netflixu.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (0%)
     (0%)
     (0%)
     (0%)
     (0%)
     (0%)
     (50%)
     (50%)
     (0%)
    Celkem 2 hlasů
     Komentářů: 5, poslední dnes 01:31
    Rozcestník

    Dotaz: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??

    2.2.2014 21:19 bajt | skóre: 1
    Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Přečteno: 691×
    Mám soubor ceny.csv s cca 5000 řádky - co řádka to číslo zboží a jeho nákupní cena bez DPH podle ktere do DB zapisuji prodejni cenu s DPH.

    Když spustím tento skript, tak běží neskutečně dlouho - kolem 4hodin.

    Jak to naprogramovat lépe aby to trvalo kratší dobu? A jak také docílit toho, aby na obrazovku postupně vypisoval,které zboží zrovna aktualizuje? ...teď totiž když tento skript spustím v prohlížeči,tak ty echa nevypisuje postupně,ale zobrazí je všechny najednou až poté co skript aktualizuje poslední řádek.

    $soubor = 'ceny.csv';

    if (!File_Exists ($soubor)) { exit("Nelze najít soubor $soubor "); } $klika = fopen($soubor, 'r'); if ($klika == false) { exit("Nelze otevřít soubor $soubor ke čtení."); } $updated = 0; $notupdated = 0; while (!feof ($klika)) { $radek = fgets($klika, 4096); list ($objednavacicislo, $nc) = explode(';', $radek); connect(); $pocet = mysql_result(mysql_query("SELECT * FROM zbozi WHERE cislo = '$objednavacicislo' LIMIT 1 "), 0); if ($pocet == 0) { echo "NOT UPDATED - $objednavacicislo does not exist!"; $notupdated = ($notupdated + 1); } else { $moc = ($nc * 1.21 * 1.1); $moc = round($moc); $aktualizaceceny = MySQL_Query("UPDATE zbozi SET cenaDPH = '$moc' WHERE cislo = '$objednavacicislo' LIMIT 1"); echo "zbozi: $objednavacicislo aktualizovano cenou $moc"; $updated = ($updated + 1); } } fclose ($klika);

    Odpovědi

    2.2.2014 21:37 Sten
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Používat prepared statements. Nepoužívat LIMIT 1, ale mít cislo jako PRIMARY KEY. A nejspíš pomůže i používání transakcí (takhle se každá změna musí commitnout samostatně).
    2.2.2014 21:40 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    • Co pohledává funkce connect() v cyklu?
    • Ten SELECT je tam úplně zbytečný.
    • Čísla se nedávají do apostrofů
    • Bylo by dobré sloupec `cislo` indexovat
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    2.2.2014 22:31 bajt | skóre: 1
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Diky za rady!

    - connect() je opravdu omylem blbe - uz je pred cyklem!

    - ten select odstranim-je tam proto,aby mi to zobrazilo i ty co nenajde a tudiz nezaktualizuje....asi to jde napsat jinak a bez nej,ale zatim nevim jak.

    - cislo $objednavacicislo neni ciste cislo,ale jen reference na kod zbozi od jednoho dodavatele, jedna se o smesici cisel a pismen, takze proto to je takto
    2.2.2014 23:47 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Nevadí, že $objednavacicislo není čisté číslo. Hlavně musí být unikátní. Pak se může stát primárním klíčem.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    Josef Kufner avatar 2.2.2014 23:47 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Také můžeš do tabulky přidat sloupeček s timestampem poslední aktualizace ceny. Na počátku importu si uložíš aktuální čas a ten pak nastavíš všem modifikovaným položkám. Pak můžeš udělat jeden select na konci a uvidíš, které položky nebyly aktualizovány (budou mít starý timestamp).

    Jen je potřeba počítat s tím, že timestampu trvá jednu sekundu, než se zvětší, takže je potřeba na začátku zkontrolovat, zda zvolený timestamp je větší než největší.
    Hello world ! Segmentation fault (core dumped)
    2.2.2014 21:52 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Místo explode() zkus ještě tohle:
    list ($objednavacicislo, $nc) = fgetCSV($klika, 4096, ";");
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    2.2.2014 22:33 bajt | skóre: 1
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Diky, vyzkousim!

    A co to postupne vypisovani na obrazovku, nevite jak toho dosahnout?
    2.2.2014 22:42 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Však to tam už máš. Zrušíš SELECT a v tom UPDATE si vždy zjistíš, kolik bylo ovlivněno řádek. Pokud 0 - neúspěch, 1 - úspěch. Pokud je "cislo" primárním klíčem, jiná situace ani nastat nemůže. Zruš ty "LIMIT 1" - jsou zbytečné.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    Josef Kufner avatar 2.2.2014 23:37 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Postupného vypisování lze dosáhnout voláním ob_flush(), pokud máš zapnutý output bufering, nebo flush() v opačném případě. Prohlížeče ale pŕi renderování HTML obvykle čekají s vykreslováním, než přijmou alespoň pár KB obsahu. U plain textu kreslí okamžitě.
    Hello world ! Segmentation fault (core dumped)
    3.2.2014 08:57 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    A načíst ten csv soubor do tabulky přímo pomocí mysql a pak udělat jenom jednoduchý update?
    TRUNCATE TABLE data_csv;
    LOAD DATA INFILE 'file_name' INTO TABLE data_csv COLUMNS TERMINATED BY ";";
    UPDATE zbozi INNER JOIN data_csv ON zbozi.cislo = data_csv. SET zbozi.cenaDPH = data_csv.nakupni_cena * 1.21 * 1.1;
    
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    10.2.2014 10:20 bajt | skóre: 1
    Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
    Vyzkousim take, dikes!

    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.