Mongodb 自动增长 自增id 实现 -1

1. Mongodb应用之id自增 

    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'=>'情绪')),当然$定位符只更新第一个匹配的元素,如果后面还有其他的话,则不会修改。 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值