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
michal_robak
post
Post #2





Grupa: Zarejestrowani
Postów: 115
Pomógł: 12
Dołączył: 13.05.2006

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


musisz po każdym rekordzie z nowego pliku sprawdzac czy juz jest w bazie jezeli nie ma to dopisujesz na końcu.

Inna opcja ... jeżeli wśród tych pól jest jakaś liczba która jest unikalna dla każdego rekordu i np nie może się powtarzać (Wykluczam identyfikator). to robisz tak.
  1. <?php
  2. $lista = array();
  3.  
  4. //dalej
  5.  
  6. //dla każdego rekordu z pierwotnej tabeli:
  7.  
  8. $lista[$numerek] = 1; //gdzie $numerek to ta unikalna liczba dla kazdego rekordu
  9.  
  10.  
  11. //nastepnie dla kazdego nowego rekordu z drugiej tabeli
  12.  
  13. if($lista[$numerek] == 0)
  14. {
  15.    zapisz ze juz nale&#380;y do listy $lista[$numerek] = 1;
  16.    dodaj wartosc do pierwtonej listy
  17. }
  18. ?>


EDIT
Po przeczytaniu że masz 52 pola ... SZOK ... juz nie bede usuwac tego co napisałem

Ten post edytował michal_robak 17.06.2009, 07:44:10
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 - 09:02