mongodb findOneAndUpdate()方法实现字段自增出现数据重复
1. 运行环境
1). 当前使用的 Laravel 版本?
5.6 5.8 lumen6.0 都出现过
2). 当前使用的 php/php-fpm 版本?
PHP 版本:7.3
php-fpm 版本:7.3
3). 当前系统
CentOS7
4). 业务环境
开发环境
5). 相关软件版本
Mongodb4.2
2. 问题描述?
使用mongodb的findOneAndUpdate()方法添加自增字段,有时候会出现数据重复的情况。
具体代码:
class Seq extends Eloquent
{
protected $connection = 'mongodb';
protected $table = 'seq';
protected $dateFormat = 'U';
protected $guarded = [];
public static function next( $_id ) {
$seq = self::raw(function($collection) use ($_id) {
return $collection->findOneAndUpdate(
['_id' => $_id],
['$inc' => array('v' => 1)],
['new' => true, 'upsert' => true]
);
});
return $seq['v'] ? $seq['v'] : self::next($_id);
}
}
3. 您期望得到的结果?
每调用一次值+1,多次调用不会出现重复值
4. 您实际得到的结果?
项目里没有相关的报错信息,大部分情况是正常的,偶尔会出现,多个项目修改同一个值的情况出现的几率稍高一些,同一个项目也会出现,而且重复出现的两条记录间隔比较大(最多间隔了1天)。
目前的配置选项,调用next()方法返回的实际上是当前的记录值,我不确定将选项里的’new’改成’returnNewDocument’是否会生效,因为目前项目较多,不方便全部修改,暂未尝试这个方法。