Insert and set value with max()+1 problems

后端 未结 11 1207
难免孤独
难免孤独 2020-12-02 16:43

I am trying to insert a new row and set the customer_id with max()+1. The reason for this is the table already has a auto_increatment on another column named id and the tabl

11条回答
  •  渐次进展
    2020-12-02 17:27

    Correct, you can not modify and select from the same table in the same query. You would have to perform the above in two separate queries.

    The best way is to use a transaction but if your not using innodb tables then next best is locking the tables and then performing your queries. So:

    Lock tables customers write;
    
    $max = SELECT MAX( customer_id ) FROM customers;
    

    Grab the max id and then perform the insert

    INSERT INTO customers( customer_id, firstname, surname )
    VALUES ($max+1 , 'jim', 'sock')
    
    unlock tables;
    

提交回复
热议问题