laravel框架中乐观锁功能的使用流程步骤
Laravel  /  管理员 发布于 2年前   907
下面例子是在laravel 8的模型中实现封装使用乐观锁功能
示例代码
1.在模型文件中
/**
* @function 实现一个简单的laravel乐观锁
* @return int 受影响的函数
* @other void
*/
public function cas() {
//首先判断数据是否存在
if(! $this->exists) {
return 0;
}
//获取那些数据是被更改的
$changed_but_no_save = $this->getDirty();
if(! $changed_but_no_save) {
return 0;
}
//判断更改的字段和查询的字段是否一致
// array_keys($this->original) 相当于select的字段
if(array_diff(array_keys($changed_but_no_save), array_keys($this->original))) {
return 0;
}
//判断是否要更新时间戳
if($this->usesTimestamps()) {
$this->updateTimestamps();
$changed_but_no_save = $this->getDirty();
}
//获取更新时间字段的字段名
$update_field_name = $this->getUpdatedAtColumn();
$updated_at_val = $this->{$update_field_name};
$query = $this->query()->where($this->getKeyName(), $this->getKey())
->when($updated_at_val, function (Builder $query) use($update_field_name, $updated_at_val) {
$query->where($update_field_name, $updated_at_val);
});
foreach($changed_but_no_save as $k => $v) {
//getOriginal(field) 源数据
$query->where($k, $this->getOriginal($k));
}
$res = $query->update($changed_but_no_save);
//同步Eorm对象数据
if($res > 0) {
$this->syncChanges();
$this->syncOriginal();
}
return $res;
}
2.使用:
$res = ModelName::find($id);
$res->field_name = value;
dd($res->cas());
这样就ok了,如果要验证的话就可以直接打印或保存sql日志查看
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号