本文介绍了Yii乐观锁的使用及原理,自己做个学习笔记,也分享给大家,希望对大家有用处

原理:
数据表中使用一个int类型的字段来存储版本号,即该行记录的版本号。更新数据时,对比版本号是否一致
sql查询代码如下(伪代码)
update `test_ver` set `name`="lili" and `ver`=2 where `id`=1 and `ver`=1
即在更新时的where查询条件中,带上之前查询记录时得到的版本号,如果其他线程已经修改了该记录,则版本号势必不会一致,则更新失败
示例
数据表
假设有如下数据表
模型类
appmodelsTestVer
该模型类,重写BaseActiveRecord类中的optimisticLock方法
声明用于记录版本号的字段
/**
* 乐观锁
* @return string
*/
public function optimisticLock()
{
return 'ver';
}
public function updateRecord(){
$ver = self::findOne(['id'=>1]);
$ver->name = "lili";
$res = $ver->update();
return $res;
}
updateRecord修改id为1的记录
控制器
控制器中调用updateRecord方法
public function actionVersion(){
$testVer = new TestVer();
$res = $testVer->updateRecord();
return $this->render('version');
}
Yii Debugger结果
查看database选项,可以查看到实际执行的sql语句。
有一条语句如下
UPDATE `test_ver` SET `name`='lili', `ver`='2' WHERE (`id`='1') AND (`ver`='1')
Yii乐观锁实现原理
实现原理在yiidbBaseActiveRecord::updateInteranl()方法
protected function updateInternal($attributes = null)
{
if (!$this->beforeSave(false)) {
return false;
}
// 获取等下要更新的字段及新的字段值
$values = $this->getDirtyAttributes($attributes);
if (empty($values)) {
$this->afterSave(false, $values);
return 0;
}
// 把原来ActiveRecord的主键作为等下更新记录的条件,
// 也就是说,等下更新的,最多只有1个记录。
$condition = $this->getOldPrimaryKey(true);
// 获取版本号字段的字段名,比如 ver
$lock = $this->optimisticLock();
// 如果 optimisticLock() 返回的是 null,那么,不启用乐观锁。
if ($lock !== null) {
// 这里的 $this->$lock ,就是 $this->ver 的意思;
// 这里把 ver+1 作为要更新的字段之一。
$values[$lock] = $this->$lock + 1;
// 这里把旧的版本号作为更新的另一个条件
$condition[$lock] = $this->$lock;
}
$rows = $this->updateAll($values, $condition);
// 如果已经启用了乐观锁,但是却没有完成更新,或者更新的记录数为0;
// 那就说明是由于 ver 不匹配,记录被修改过了,于是抛出异常。
if ($lock !== null && !$rows) {
throw new StaleObjectException('The object being updated is outdated.');
}
$changedAttributes = [];
foreach ($values as $name => $value) {
$changedAttributes[$name] = isset($this->_oldAttributes[$name]) ? $this->_oldAttributes[$name] : null;
$this->_oldAttributes[$name] = $value;
}
$this->afterSave(false, $changedAttributes);
return $rows;
}
从上面的代码中,我们不难得出:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Yii乐观锁
# Yii乐观锁原理
# 深入理解Yii2.0乐观锁与悲观锁的原理与使用
# 主键
# 抛出
# 的是
# 过了
# 那就
# 最多
# 一是
# 两种
# 却没有
# 第二个
# 给大家
# 做个
# 重写
# 即在
# 大家多多
# 可以查看
# 不满足
# 数为
# 则更
# 学习笔记
相关文章:
如何通过VPS建站无需域名直接访问?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
英语简历制作免费网站推荐,如何将简历翻译成英文?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
已有域名能否直接搭建网站?
青岛网站建设如何选择本地服务器?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
如何在IIS中配置站点IP、端口及主机头?
网站网页制作专业公司,怎样制作自己的网页?
魔毅自助建站系统:模板定制与SEO优化一键生成指南
建站之星如何实现五合一智能建站与营销推广?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
想学网站制作怎么学,建立一个网站要花费多少?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何用西部建站助手快速创建专业网站?
javascript中对象的定义、使用以及对象和原型链操作小结
建站之星CMS建站配置指南:模板选择与SEO优化技巧
实例解析angularjs的filter过滤器
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
如何选择CMS系统实现快速建站与SEO优化?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
如何在Ubuntu系统下快速搭建WordPress个人网站?
贸易公司网站制作流程,出口贸易网站设计怎么做?
如何在建站宝盒中设置产品搜索功能?
北京企业网站设计制作公司,北京铁路集团官方网站?
如何用PHP工具快速搭建高效网站?
如何通过WDCP绑定主域名及创建子域名站点?
如何快速查询网站的真实建站时间?
免费视频制作网站,更新又快又好的免费电影网站?
如何用已有域名快速搭建网站?
如何构建满足综合性能需求的优质建站方案?
建站之星如何快速生成多端适配网站?
婚礼视频制作网站,学习*后期制作的网站有哪些?
长沙企业网站制作哪家好,长沙水业集团官方网站?
如何快速搭建高效香港服务器网站?
网站专业制作公司有哪些,做一个公司网站要多少钱?
详解jQuery中基本的动画方法
如何快速搭建FTP站点实现文件共享?
如何在云虚拟主机上快速搭建个人网站?
建站之星导航菜单设置与功能模块配置全攻略
制作公司内部网站有哪些,内网如何建网站?
如何快速完成中国万网建站详细流程?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】
建站之星如何取消后台验证码生成?
如何基于云服务器快速搭建个人网站?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
建站org新手必看:2024最新搭建流程与模板选择技巧
*请认真填写需求信息,我们会在24小时内与您取得联系。