Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [mySQL] Jak usunąć dużą liczbę rekordów?
yalus
post 12.02.2010, 14:36:57
Post #1





Grupa: Zarejestrowani
Postów: 281
Pomógł: 0
Dołączył: 8.07.2005
Skąd: EU

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


witam

w bazie mam dwie tabele i teraz chcialbym z jednej usunac te same rekordy, ktore znajduja sie w drugiej

uzywam do tego takiego oto zapytania:

  1. DELETE FROM tblcustomers WHERE EXISTS (SELECT incorrect_numb.mobile_number FROM incorrect_numb WHERE tblcustomers.mobile_number = incorrect_numb.mobile_number);


niestety takie zapytanie wykonywane jest b. dlugo (podzapytanie itp) a do usuniecia mam ponad 60.000 rekordow
czy jest jakis sposob aby zrobic to szybciej?


pozdrawiam


--------------------
człowiek nie sznurek wszystko wytrzyma
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
skowron-line
post 12.02.2010, 15:07:57
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


Możesz sobie również podzielić to na części żeby odrazu 60 000 nie usuwać
  1. $affected_rows = 1;
  2. while( $affected_rows > 0 )
  3. {
  4. mysql_query('delete from tabela limi 10000');
  5. $affected_rows = mysql_affected_rows();
  6. }


--------------------
I'm so fast that last night I turned off the light switch in my hotel room and was in bed before the room was dark - Muhammad Ali.
Peg jeżeli chcesz uprawiać sex to dzieci muszą wyjść, a jeżeli chcesz żeby był dobry ty też musisz wyjść - Al Bundy.

QueryBuilder, Mootools.net, bbcradio1::MistaJam
http://www.phpbench.com/
Go to the top of the page
+Quote Post

Posty w temacie


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

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 20:52