关于INNODB 锁的问题.

浏览:716 发布日期:2016/02/01 分类:求助交流
场景 一个电子商务平台 的购物车结算.

查询 用户 余额
$user = D("user");
$user->startTrans();//开启事务,,这里我同时查询了几个表,只设置一次开启事务吗?
$userinfo = $user->lock(true)->where("id=1")->select();

查询商品总价,同时减少商品库存
$goods = D("goods");
$goodsinfo = $goods->lock(true)->where("gid=300")->select();

if($userinfo & $goodsinfo){
......
if(true){
$user->commit();//提交事务.
}else{
$user->rollback();//回滚
}
}


这里有几个问题,
1:查询多表时,只提交一个事务吗?
2:以上代码有2个lock,我试过,在2个select()后,加上 sleep(50);后,
在去cmd命令下,查询 user表的id=10 goods表的 gid=999,是在等待状态,证明了,这个上锁是表级锁,,我想行级锁,我应该怎么做?找了好多资料,貌似都没行级锁,难道要自己写原生吗?
最佳答案
评论( 相关
后面还有条评论,点击查看>>