Mongodb 自动增长 自增id 实现 -1
2014-12-13 08:45
417 查看
1. Mongodb应用之id自增
Mongo中也是可以去字段进行自增的,以下是封装的一个获取自增id的方法,用的是Mongo的command命令实现的。
2. Mongodb应用之$push 和$pull 、操作定位符($):
经常遇到这种情况,说一篇文章有多个评论,或者跟某个分类加上若干个标签,我们在用Mysql时,可能会用到外键,但是现在用Mongo我们就不必用外键了,直接可以用Mongo的内部文档,如下:
比如说,我想要再添加一个标签,
$params['name'] = '小情绪';
$params['ctim'] = time();
$db->table->update(array('_id'=>2), array('$push'=>array('tag'=>$params))); 这样就会添加进去了!
当然,有添加,自然就会有删除的。删除可以用在这里我们需要用到$pull,还有其他$unset(视情况而定),
$db->table->update(array('_id'=>$id), array('$pull'=>array('tag'=>array('name'=>'小情绪'))));在用$pull时请注意,再最后那个array('$pull'=>array('tag'=>array('name'=>'小情绪')))时,不能用array('$pull'=>array('tag.name'=>'小情绪'));这样是删除不了数据的,这个是必须注意的。因为你删除的是整个标签的数据,而不是某个分类标签的某个字段。
再说一下,关于内部文档的修改,比如说我想把小情绪修改为情绪,我们可以用array('$unset'=>array('tag.4.name'=>'情绪'))。但这是在我们知道他索引的情况下,但是我们再不知道的情况下呢,所以这块又引出来一个定位操作符$,因此我们在修改的时候就不用担心了:
array('$unset'=>array('tag.$.name'=>'情绪')),当然$定位符只更新第一个匹配的元素,如果后面还有其他的话,则不会修改。
Mongo中也是可以去字段进行自增的,以下是封装的一个获取自增id的方法,用的是Mongo的command命令实现的。
function genId($db, $name){ $command['findAndModify'] = 'ids'; $command['query'] = array('name' => $name); $command['update'] = array('$inc' => array('id' => 1)); $command['upsert'] = true;//若是第一次创建,upsert一定要写上,否则,不会出现自增id $command['new'] = true; $data = $db->command($command); if (isset($data['ok']) && $data['value']['id']) { return $data['value']['id']; } return false; } $id = genId($db, 'cid');
2. Mongodb应用之$push 和$pull 、操作定位符($):
经常遇到这种情况,说一篇文章有多个评论,或者跟某个分类加上若干个标签,我们在用Mysql时,可能会用到外键,但是现在用Mongo我们就不必用外键了,直接可以用Mongo的内部文档,如下:
{ "_id": 2, "catename": "情感心绪", "ctime": 1377227846, "tag": { "0": { "name": "浪漫爱情", "ctim": 1377487297 }, "1": { "name": "亲情", "ctim": 1377489650 }, "2": { "name": "友情", "ctim": 1377489657 }, "3": { "name": "星座", "ctim": 1377489672 }, "4": { "name": "小情绪", "ctim": 1377489685 } } }
比如说,我想要再添加一个标签,
$params['name'] = '小情绪';
$params['ctim'] = time();
$db->table->update(array('_id'=>2), array('$push'=>array('tag'=>$params))); 这样就会添加进去了!
当然,有添加,自然就会有删除的。删除可以用在这里我们需要用到$pull,还有其他$unset(视情况而定),
$db->table->update(array('_id'=>$id), array('$pull'=>array('tag'=>array('name'=>'小情绪'))));在用$pull时请注意,再最后那个array('$pull'=>array('tag'=>array('name'=>'小情绪')))时,不能用array('$pull'=>array('tag.name'=>'小情绪'));这样是删除不了数据的,这个是必须注意的。因为你删除的是整个标签的数据,而不是某个分类标签的某个字段。
再说一下,关于内部文档的修改,比如说我想把小情绪修改为情绪,我们可以用array('$unset'=>array('tag.4.name'=>'情绪'))。但这是在我们知道他索引的情况下,但是我们再不知道的情况下呢,所以这块又引出来一个定位操作符$,因此我们在修改的时候就不用担心了:
array('$unset'=>array('tag.$.name'=>'情绪')),当然$定位符只更新第一个匹配的元素,如果后面还有其他的话,则不会修改。
相关文章推荐
- Mongodb 自动增长 自增id 实现
- Mongodb 自动增长 自增id 实现
- Mongodb 自动增长 自增id 实现 -2
- Mongodb 自动增长 自增id 实现 -3 PHP
- MongoDB自动增长id实现、自定义函数调用、与Spring集成
- MongoDB 实现字段自动增长id Mongodb auto increment ID
- MongoDB自动增长id实现、自定义函数调用、与Spring集成
- Mongodb 自动增长 自增id 实现
- 一个通用的单元测试框架的思考和设计07-实现篇-自动管理测试数据-如何为自增长主键id赋值
- Oracle 表创建序列-触发 实现表ID自动增长
- 如何实现字符串类型的ID自动增长
- SQL Server中根据某个字段,ID字段自动增长的实现
- MongoDB实现ID自增长
- oracle 序列 + 触发器 实现 ID自动增长
- hibernate oracle ID自动增长的实现
- oracle主键自动增长的实现 Oracle Sequence oracle maxid自动生成--ORA-00001: 违反唯一约束条件 (NAME.SYS_C005547)产生的原因之一(select * from all_cons_columns w
- MongoDB自增长ID的实现
- SpringBoot入门-17(springboot集成mybatis注解形式实现ID自动增长)
- mysql实现id自动增长
- Spring-boot mongodb ID自增长注解实现 适用于JDK 1.7和JDK 1.8