> 백엔드 개발 > PHP 튜토리얼 > YII中的updateByPk中的参数是不是有点鸡肋?

YII中的updateByPk中的参数是不是有点鸡肋?

WBOY
풀어 주다: 2016-06-06 20:45:17
원래의
1106명이 탐색했습니다.

这updateByPk有四个参数,其中第三个参数我感觉有点鸡肋。因为第三个参数是条件。那我主键只有一个,我干嘛还要整一个条件呢?也就是通过主键就能找到唯一的列,我还要条件干啥啊!

回复内容:

这updateByPk有四个参数,其中第三个参数我感觉有点鸡肋。因为第三个参数是条件。那我主键只有一个,我干嘛还要整一个条件呢?也就是通过主键就能找到唯一的列,我还要条件干啥啊!

不是。
首先,最后两个参数是可以省略的,对于简单的更新,这个方法调用很方便。
其次,如果更新还包含其它限制,那么后面的两个参数就派上用场了。一般情况下,用主键来唯一确定一条记录,这里把主键写在第一参数位置,可以突出主键,出错的概率更小。

比如用户要更新自己写的文章,那一般都是先靠主键定位到文章ID,再通过附加条件“uid=:uid”来确定是当前用户来防止其他用户提交恶意ID来做修改。(目前我只有这种应用场景用到第三个参数)

比如你要更新ID为3的帐号给他扣除10块钱

读余额,然后直接updateByPk

然后你就完蛋了,因为交易频率高的时候,不能保证你读到余额以后,没有别的进程写了另一个新的余额进去,连买2个却只扣了一次钱之类的问题就来了

这时候就需要加条件了,具体来说

<code>balance, version = readByPk pk
balance -= 10
updateBypk pk, {balance:balance, version:version+1}, version=version
</code>
로그인 후 복사

通过“版本号”防止并发场景下数据错乱。好像行话叫乐观锁,可以去了解一下

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿