Portál AbcLinuxu, 25. dubna 2024 01:55


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: 640×
Odpovědět | Admin
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);
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

2.2.2014 21:37 Sten
Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
Odpovědět | | Sbalit | Link | Blokovat | Admin
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: 45 | Brno
Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
Odpovědět | | Sbalit | Link | Blokovat | Admin
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: 45 | 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: 45 | Brno
Rozbalit Rozbalit vše Re: Jak vylepšit (zrychlit) aktualizaci cen v MySQL pomoci PHP ??
Odpovědět | | Sbalit | Link | Blokovat | Admin
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: 45 | 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 ??
Odpovědět | | Sbalit | Link | Blokovat | Admin
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, (c) 1999-2007 Stickfish s.r.o.