• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

在MongoDB中模拟Auto Increment的php代码

php 搞代码 4年前 (2022-01-01) 46次浏览 已收录 0个评论

MySQL用户多半都有Auto Increment情结,不过MongoDB缺省并没有实现,所以需要模拟一下,编程语言以PHP为例

代码大致如下所示:

代码如下:
<?php
function generate_auto_increment_id($namespace, array $option = array())
{
$option += array(
‘init’ => 1,
‘step’ => 1,
);
$instance = new Mongo();
$instance = $instance->selectCollection(‘_seq’, ‘seq’);
$seq = 来源gaodaimacom搞#代%码网$instance->db->command(array(
‘findAndModify’ => ‘seq’,
‘query’ => array(‘_id’ => $namespace),
‘update’ => array(‘$inc’ => array(‘id’ => $option[‘step’])),
‘new’ => true,
));
if (isset($seq[‘value’][‘id’])) {
return $seq[‘value’][‘id’];
}
$instance->insert(array(
‘_id’ => $namespace,
‘id’ => $option[‘init’],
));
return $option[‘init’];
}
var_dump(generate_auto_increment_id(‘foo’));
var_dump(generate_auto_increment_id(‘bar’, array(‘init’ => 123)));
?>

其具体实现方式主要是利用MongoDB中findAndModify命令,只要每次往MongoDB里insert对象前生成ID赋值给_id就OK了,因为它的实现满足原子性,所以不存在并发问题。

另外说明一点,findAndModify本身提供了一个upsert参数,为true的话可以自动insert,但那样就不能自定义初始值了,所以文中示例没有使用upsert。

BTW,数据库“_seq”的名字以下划线开头,这样列表的时候会排在前面,更容易分辨些。

参考:Auto Increment with MongoDB

以上就是在MongoDB中模拟Auto Increment的php代码的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:在MongoDB中模拟Auto Increment的php代码
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址