MySQL – Trigger for updating same table after insert

It seems that you can’t do all this in a trigger. According to the documentation:

Within a stored function or trigger, it is not permitted to modify a table that is already being used (for reading or writing) by the statement that invoked the function or trigger.

According to this answer, it seems that you should:

create a stored procedure, that inserts into/Updates the target table, then updates the other row(s), all in a transaction.

With a stored proc you’ll manually commit the changes (insert and update). I haven’t done this in MySQL, but this post looks like a good example.

Leave a Comment