ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

tp5 lock的使用

2021-01-09 10:02:36  阅读:265  来源: 互联网

标签:行级 lock 数据库 tp5 使用 model where id


首先我们了解一下数据库的锁,数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性,

(注意事项:首先,数据库类型要是InnoDB,其次,加锁必须跟事务同时使用)。

在tp5中如何使用:请看以下代码

复制代码
public function testTrans(){
    $time = date('H:i:s');
    $model = new \app\model\Student();
    $model->startTrans();//开启事务
    try{
        $student = $model->lock(true)->where('id', 4)->find();//加锁
        $student->update(['age' => $student['age']+10], ['id' => 4]);
        sleep(20);
        $model->commit();//事务提交
        return $time.'_lock_true_'.date('H:i:s');
    } catch (\Exception $e) {
        $model->rollback();
        throw $e;
    }
    return $time.'_lock_false_'.date('H:i:s');
}
复制代码

InnoDB 预设是Row-Level Lock (行级锁),FOR UPDATE 需要指定明确的主键才会行级锁,否则为表级锁,如:

select from user where id = 1 (行级锁)

select from user where id > 1 (表级锁)

操作完成后无需手动解锁,会自动解锁

标签:行级,lock,数据库,tp5,使用,model,where,id
来源: https://www.cnblogs.com/xiaogou/p/14254182.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有