mongodb php auto increment 自增
mongodb的自增实现根oracle,postgresql是差不多,都是通过计数器来实现的.
oracle自增实现: 实例说明oracle序列用法
postgresql自增实现: postgresql auto_increment 实现 通用方法
1,mongodb命令行下实现auto_increment
- > db.counters.insert( //计数器表
- {
- _id: "userid",
- seq: 0
- }
- );
- WriteResult({ "nInserted" : 1 })
- > db.counters.find();
- { "_id" : "userid", "seq" : 0 }
- > function getNextSequence(name) { //取下个ID的函数
- var ret = db.counters.findAndModify(
- {
- query: { _id: name },
- update: { $inc: { seq: 1 } }, //这里seq就是上面counters表中的seq字段
- new: true,
- upsert: true
- }
- );
- return ret.seq;
- };
- > db.users.insert( //插入数据
- {
- _id: getNextSequence("userid"),
- name: "tank"
- }
- );
- WriteResult({ "nInserted" : 1 })
- > db.users.find(); //查看
- { "_id" : 1, "name" : "tank" }
- > db.users.insert(
- {
- _id: getNextSequence("userid"),
- name: "test"
- }
- );
- WriteResult({ "nInserted" : 1 })
- > db.users.find();
- { "_id" : 1, "name" : "tank" }
- { "_id" : 2, "name" : "test" }
2,php实现auto_increment
- function getNextId($mongo,$name,$param=array()){
- $param += array( //默认ID从1开始,间隔是1
- 'init' => 1,
- 'step' => 1,
- );
- $update = array('$inc'=>array('id'=>$param['step'])); //设置间隔
- $query = array('name'=>$name);
- $command = array(
- 'findandmodify' => 'ids',
- 'update' => $update,
- 'query' => $query,
- 'new' => true
- );
- $id = $mongo->db->command($command);
- if (isset($id['value']['id'])) {
- return $id['value']['id'];
- }else{
- $mongo->insert(array(
- 'name' => $name,
- 'id' => $param['init'], //设置ID起始数值
- ));
- return $param['init'];
- }
- }
- $mongo = new Mongo();
- $curDB = $mongo->selectCollection('test', 'ids'); //test库中的ids表
- $user = $mongo->selectCollection('test', 'users'); //test库中的users表
- $id = getNextId($curDB,'userid',array('init'=>10000,'step'=>2)); //取得下一条数据的ID
- $obj = array("_id"=>$id,"name"=>"tankzhang");
- $user->insert($obj); //插入数据
mongodb php auto increment 自增的更多相关文章
- mongodb 创建auto increment 自增函数
计数器表 > db.counters.insert({_id: "userid",seq: 0} ); > db.counters.find(); { " ...
- SQL——AUTO INCREMENT(字段自增)
AUTO INCREMENT -- 在新记录插入表中时生成一个唯一的数字.插入表数据时,该字段不需规定值. 在每次插入新记录时,自动地创建主键字段的值.在表中创建一个 auto-incremen ...
- MongoDB下载安装与简单增删改查
Windows下MongoDB的安装和配置.启动和停止 下载地址:MongoDB的官方下载网址是:https://www.mongodb.org/downloads 安装步骤1. 点击下载的mongo ...
- SQL AUTO INCREMENT 字段
Auto-increment 会在新记录插入表中时生成一个唯一的数字. AUTO INCREMENT 字段 我们通常希望在每次插入新记录时,自动地创建主键字段的值. 我们可以在表中创建一个 auto- ...
- sql server auto increment - trace flag 272
从 sql 2012 开始, 微软为了让 insert 时 auto increment 快一些,做了一个 cache 的机制. 这个机制虽然好,但是也有麻烦的情况,如果你的 sql 突然 resta ...
- 19. AUTO INCREMENT 字段
Auto-increment 会在新记录插入表中时生成一个唯一的数字. AUTO INCREMENT 字段 我们通常希望在每次插入新记录时,自动地创建主键字段的值. 我们可以在表中创建一个 auto- ...
- SQL-W3School-高级:SQL AUTO INCREMENT 字段
ylbtech-SQL-W3School-高级:SQL AUTO INCREMENT 字段 1.返回顶部 1. Auto-increment 会在新记录插入表中时生成一个唯一的数字. AUTO INC ...
- mysql AUTO INCREMENT字段 语法
mysql AUTO INCREMENT字段 语法 作用:在新记录插入表中时生成一个唯一的数字 说明:我们通常希望在每次插入新记录时,自动地创建主键字段的值.我们可以在表中创建一个 auto-incr ...
- Node.js、express、mongodb 入门(基于easyui datagrid增删改查)
前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验 ...
随机推荐
- JS操作Cookies的小例子
这篇文章介绍了JS操作Cookies的小例子,有需要的朋友可以参考一下. 您可能感兴趣的文章:js 保存与获取cookie的代码javascript cookie操作实例详解javascript co ...
- U3D-LookAt插值动画
var qua = Quaternion.FromToRotation(Vector3.forward, target.transform.position - transform.position) ...
- HDU 4952 Poor Mitsui(贪心)
HDU 4957 Poor Mitsui pid=4957" style="">题目链接 思路:利用相邻交换法去贪心就可以.注意容积为0的情况,这是个坑点 代码: ...
- Oracle某些功能实现语句处理方法
触发器以及序列CREATE OR REPLACE TRIGGER t_MSTB_BDS_DATA BEFORE INSERT ON MSTB_BDS_DATA FOR EACH ROW DECLARE ...
- ny488 素数环
素数环 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 有一个整数n,把从1到n的数字无重复的排列成环,且使每相邻两个数(包括首尾)的和都为素数,称为素数环. 为了简便起 ...
- Linux Jenkins配置Git
1.卸载Centos自带的git1.7.1:通过git –version查看系统带的版本,Centos应该自带的是git版本是1.7.1 终端输入:yum remove git 2.安装所需软件包 终 ...
- 【java web】Caused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
javaweb报错如下:22:49:22.155 [http-nio-8081-exec-9] ERROR org.apache.struts2.dispatcher.DefaultDispatche ...
- python map函数的使用
python2 中的map函数返回列表 python3 中的map函数返回迭代器 >>>def square(x) : # 计算平方数 ... return x ** 2 ... & ...
- mysql show full processlist
processlist命令的输出结果显示了有哪些线程在运行,可以帮助识别出有问题的查询语句,两种方式使用这个命令. 1. 进入mysql/bin目录下输入mysqladmin -u -p -h127. ...
- python学习笔记(14)--爬虫下载漫画图片修改版
说明: 1. 2017.3.12,周六从中午吃完包子12点多折腾了一下午加一个晚上,试了4个网站的爬虫,发现都不能下载!甚至前几天测试能下载的都不能用了! 2. 到晚上发现煎蛋网的可以用了,立即试了下 ...