Hey guys quick question, I currently have an insert statement
$query= "INSERT into new_mail VALUES ('$to1', '0')"; where fields are username, and message_number
Currently what I would do to check if the entry exists, is do a select query then check the number of rows with mysql_num_rows (php). If rows==1 then I get the current message_number and set it equal to
$row['message_number']+1.
Then I update that entry with another query.
Is there an easier way to do all this in just mysql with just one query (check if exists, if not insert, if so update message_number, increase by 1)?
Use
INSERT...ON DUPLICATE KEY UPDATE. The MySQL manual has an example which does almost exactly what you need:To make this work you need to add a UNIQUE index on the column that you use to check for duplicates. There is one important warning though: