Hubert Perron Hubert Perron - 1 year ago 77
SQL Question

Ignoring locked row in a MySQL query

I have one table that is read at the same time by different threads.

Each thread must select 100 rows, execute some tasks on each row (unrelated to the database) then they must delete the selected row from the table.

rows are selected using this query:


My question is: How can I ignore (or skip) rows that were previously locked using a select statement in MySQL ?

Answer Source

I typically create a process_id column that is default NULL and then have each thread use a unique identifier to do the following:

UPDATE table_name SET process_id = #{} WHERE process_id IS NULL LIMIT 100;

SELECT id FROM table_name WHERE process_id = #{} FOR UPDATE;

That ensures that each thread selects a unique set of rows from the table.

Hope this helps.

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download