php mysql 锁表,如何在PHP中锁定MySQL表

How do I lock mysql tables in php? I currently have this code:

$db->query("LOCK TABLES tbl_othercharge WRITE");

for($x=0;$x<=500; $x++){

$id = get_max();

$db->query("INSERT INTO tbl_othercharge SET tblocID = '$id', assessmentID='lock1'");

}

$db->query("UNLOCK TABLES");

Here's the get_max() function, which obviously will fail if the script above executes simultaneously.

function get_max(){

global $db;

$max = $db->get_var("SELECT MAX(tblocNumber) FROM tbl_othercharge");

if($max == null){

$max = 1;

}else if($max >= 1){

$max = $max + 1;

}

return 'OC'.$max;

}

?>

I'm trying to test if there are still concurrency problems by executing the same script on 2 browsers.

The script above inserts 400+ records instead of 999 records. How do I properly lock the table while I'm inserting something into it.

I want to lock the table to prevent something like this to happen:

miKUa.png

As you can see the field with the prefix 'OC' on it should have a number which is equal to the auto-increment primary key.

解决方案

The only reliable solution is to do an insert with a dummy value, getting the last insert id, and updating the row to the correct value.

mysql_query("INSERT INTO table (field) VALUES (dummy);");

$id = mysql_last_insert_id();

mysql_query("UPDATE table SET field='OC{$id}' WHERE id={$id} LIMIT 1;");

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值