测试的时候增加积分正常,到运营环境就出现部分账户异常,积分都是正常添加的时候有明细记录,可是明细记录上的数量正常,
到账却多出一部分数量,本地测试没出现这样问题,代码也是用事务运行,多人一起参与使用的时候就出现,比如三百个账户,就有十多个异常数量的账户。
```php
Db::name('user')->where(['id' => $v['id']])->update([ 'integral' => Db::raw('integral + '. $num)]);
```
测试的时候增加积分正常,到运营环境就出现部分账户异常,积分都是正常添加的时候有明细记录,可是明细记录上的数量正常,
到账却多出一部分数量,本地测试没出现这样问题,代码也是用事务运行,多人一起参与使用的时候就出现,比如三百个账户,就有十多个异常数量的账户。
```php
Db::name('user')->where(['id' => $v['id']])->update([ 'integral' => Db::raw('integral + '. $num)]);
```
你的积分系统应该是每天有一个表,一笔一笔的记录,显示的时候sum起来,为了提高效率可以定时(比如每天3:00)锁表并将临时记录重新写到另一个表里,此时直接加。
虽然你使用了事务,但是事务本身是在客户端而不是数据库内部,要么你改用存储过程,避免脏数据