Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP][MYSQL] insert bez powtórzeń, uzupełnienie bazy
cerberpat
post
Post #1





Grupa: Zarejestrowani
Postów: 27
Pomógł: 0
Dołączył: 20.05.2009

Ostrzeżenie: (0%)
-----


Witam wszystkich (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) moje pytanie brzmi następująco jak wpisać różnicę danych… tzn. mam tabele która ma jakieś 200 000 rekordów i plik który zawiera 95% tych samych rekordów + część nowych i teraz jak je dopisać, aby wpisać tylko te nowe?(IMG:http://forum.php.pl/style_emoticons/default/questionmark.gif) Zamiana niestety odpada ponieważ do tabeli tez są wpisywane dane których znowu plik nie posiada… No i musi dopisywać rekordy jeśli od istniejących różnią się choć jednym polem…
Z góry dzięki za pomoc (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
Pilsener
post
Post #2





Grupa: Zarejestrowani
Postów: 1 590
Pomógł: 185
Dołączył: 19.04.2006
Skąd: Gdańsk

Ostrzeżenie: (0%)
-----


A nie prościej po prostu dodać pole "suma kontrolna"?

Suma kontrolna = md5(pole1 + pole2 + pole3 + pole4 + poleN)

Ten sam hasz oznacza, że na 99,9999% rekordy są identyczne i nie pozwalasz ich dodać, wystarczy:

1. Dodać do bazy takie pole i nadać mu indeks unique
2. Wykonać odpowiednie operacje na wszystkich rekordach
3. Wykonać odpowiednie operacje w pliku z danymi (while + fgets + feof)
4. Dodać plik korzystając z LOAD DATA INFILE, oczywiście zostaną dodane tylko te rekordy, które nie powodują konfliktu w polu "suma kontrolna"

Ja tak robię, bo mam dane gdzie raz klienta identyfikuje po nr tel, innym razem po pesel, innym po regon, nip, nr paszportu, prawo jazdy... życie (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 5.10.2025 - 19:52