IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

在MongoDB中模拟auto_increment

火丁笔记 2011-02-09 22:11:23 累计浏览 4,141 次
本机暂存

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 = $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'));

?>

其具体实现方式主要是利用MongoDB中findAndModify命令,因为它的实现满足原子性,所以不存在并发问题。有了这个自增ID生成器,只要每次往MongoDB里insert对象前设置一下_id就OK了,如果有数据抽象层,可以在里面封装这个过程,便可实现透明性。

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

参考:Auto Increment with MongoDB

同分类推荐文章

  1. 使用deepseek进行Oracle恢复,引起重大故障 (2026-06-22 10:56:00)
  2. 接手一个只差临门一脚的数据库恢复 (2026-06-18 00:13:09)
  3. 我做了一个 AI 版的 StarRocks 升级风险扫描工具,直接帮我定位到一个风险 (2026-06-15 01:00:00)

查看更多 数据库 文章 →

建议继续学习

  1. 使用gettext来支持PHP的多语言 (累计阅读 39,270)
  2. WordPress插件开发 -- 在插件使用数据库存储数据 (累计阅读 29,164)
  3. Paypal接口详细代码(PHP版,非API接口) (累计阅读 19,408)
  4. 什么是全栈工程师? (累计阅读 14,038)
  5. 我的PHP,Python和Ruby之路 (累计阅读 13,149)
  6. include(“./file.php”)和include(“file.php”)区别 (累计阅读 12,789)
  7. 15个最好的免费开源电子商务平台 (累计阅读 12,541)
  8. Redis消息队列的若干实现方式 (累计阅读 12,088)
  9. 到底什么是MVC? (累计阅读 11,868)
  10. 整理了一份招PHP高级工程师的面试题 (累计阅读 11,709)