Mailing List
Home
Forum Home
MySQL General - General MySQL discussion
MySQL++ - Programming with the C++ API to MySQL
MaxDB - Everything about MaxDB, formerly known as SAP DB
ODBC - ODBC with the MySQL Connector/ODBC driver
MySQL on Win32 - Runing MySQL on Windows 9x/Me/NT/2000/XP
Java Help - Mostly related to the MySQL Connector/J driver
Perl - Perl support for MySQL with DBI and DBD::mysql
GUI - MySQL GUI Tools
Announcement
Subjects
Subject: mysql openssl Question
ERROR 1045: Access denied for user: 'root@localhost ' (Using
password: NO)
Update one field with more fields from another table
Subject: Getting Identity after INSERT
ERROR 2002: Can 't connect to local MySQL server through socket
mysql test 4 1 fails with the gis test
Subject: MySQL Cluster Software
Downgrade Mysql from 4 to 3 23
Mysql 4 0 Oracle Stored Procedure Trigger Conversion
Can 't access mysql after kernel upgrade
Executing MySQL Commands From Within C Program
Comparing and writing out BLOBS
Subject: Re: Preventing Duplicate Entries
FULLTEXT query format question
Strange behavior, Table Level Permission
Does the binary log enabling affect the MySQL performances?
mysql:it 's a db not a dbms how it 's possible?!
mysql have same function mthod as Oracle decode()
 
Subject: Re: Which is faster when deleting rows? In() or Separate Delete stmts?

Subject: Re: Which is faster when deleting rows? In() or Separate Delete stmts?

2007-11-03       - By Baron Schwartz

 Back
Hi

mos wrote:
> If I have a large table with 20 million rows, is it going to be faster
> to use one delete statement like:
>
> delete from mytable where rcdid in(20,300,423, .... 99999)
>
> to delete 10-100 random records using the primary index "RcdId"
>
> or should I use separate delete statements for each RcdId as in:
>
> delete from mytable where rcdid = 20;
> delete from mytable where rcdid = 300;
> delete from mytable where rcdid = 423;
> ...
> delete from mytable where rcdid = 99999;
>
> I'm concerned the IN() clause will cause a full table scan and that will
> take quite a while to find the rows even though I'm using the primary
> key RcdId.

You can convert it into an equivalent SELECT and use EXPLAIN to see if
it's using a table scan.

Baron

--
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe:    http://lists.mysql.com/mysql?unsub=mysql@(protected)