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 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 3
    dnes 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 19
    dnes 09:33 | IT novinky

    Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.

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

    Byla vydána betaverze Fedora Linuxu 44 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 14. dubna.

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

    Open source router Turris Omnia NG Wired je v prodeji. Jedná se o Turris Omnia NG bez Wi-Fi. Je připraven pro zamontování do racku.

    Ladislav Hagara | Komentářů: 6
    včera 11:44 | Pozvánky

    Sníh roztál a roztávají i bastlíři. Žene se na nás celá řada konferencí a seminářů technického rázu. Zajímá vás, jaké? Pak se připojte k 60. Virtuální Bastlírně, tedy k veřejné diskuzi bastlířů, techniků, učitelů i vědců. Jako vždy přijde na přetřes spousta novinek ze světa hardwaru, softwaru i bizáru. Na začátek lze očekávat hardwarová témata, tedy například nový KiCAD 10, nové akcelerátory LLM s nízkou spotřebou, nejvíce fosforeskující

    … více »
    bkralik | Komentářů: 1
    včera 11:22 | Zajímavý článek

    IuRe (Iuridicum Remedium) v rámci programu Digitální svobody zveřejnila analýzu dopadů a efektivity systémů ověřování věku v digitálním prostoru, která srovnává implementace ověřování věku v Austrálii, Velké Británii a Evropské unii.

    |🇵🇸 | Komentářů: 1
    včera 04:22 | Nová verze

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.3 (𝕏, Mastodon). Přehled novinek a vylepšení v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 03:55 | Nová verze

    Byla vydána nová verze 14.4 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 5
    9.3. 23:22 | Nová verze

    Databáze DuckDB (Wikipedie) byla vydána ve verzi 1.5.0. S kódovým názvem Variegata (husice rajská). Přináší řadu vylepšení, včetně nového ergonomičtějšího CLI klienta nebo podporu pro typ VARIANT a vestavěný typ GEOMETRY.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (6%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 1053 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    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: 694×
    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.