您的位置:首页 > 数据库 > Mongodb

Mongodb特殊的更新操作

2013-11-08 13:12 218 查看
1.在原来的字段基础上,加上一个数字 针对数值型

$bool = $table->update(array("name"=>"name1"),array('$inc'=>array("age"=>1000)));
var_dump($bool);


2.让某个字段等于固定的值

$bool = $table->update(array("name"=>"name1"),array('$set'=>array("age"=>22222)));
var_dump($bool);


3.删除某个节点的值

$bool = $table->update(array("name"=>"name1"),array('$unset'=>array("age"=>1)));
var_dump($bool);

多项删除
$table->remove(array("name"=>array('$in'=>array("name3","name4"))));


$push

如果对应节点是个数组,就附加一个新的值上去;不存在,就创建这个数组,并附加一个值在这个数组上;如果该节点不是数组,返回错误。

设记录结构为array(’a'=>array(0=>’haha’),’b'=>1),想附加新数据到节点a,那么:

$coll->update(

array(’b'=>1),

array(’$push’=>array(’a'=>’wow’)),

)

这样,该记录就会成为:array(’a'=>array(0=>’haha’,1=>’wow’),’b'=>1)

$pushAll

与$push类似,只是会一次附加多个数值到某节点

$addToSet

如果该阶段的数组中没有某值,就添加之

设记录结构为array(’a'=>array(0=>’haha’),’b'=>1),如果想附加新的数据到该节点a,那么:

$coll->update(

array(’b'=>1),

array(’$addToSet’=>array(’a'=>’wow’)),

)

如果在a节点中已经有了wow,那么就不会再添加新的,如果没有,就会为该节点添加新的item——wow。

$pop

设该记录为 array(’a'=>array(0=>’haha’,1=>’wow’),’b'=>1)

删除某数组节点的最后一个元素:

$coll->update(

array(’b'=>1),

array(’$pop=>array(’a'=>1)),

)

删除某数组阶段的第一个元素

$coll->update(

array(’b'=>1),

array(’$pop=>array(’a'=>-1)),

)

$pull

如果该节点是个数组,那么删除其值为value的子项,如果不是数组,会返回一个错误。

设该记录为 array(’a'=>array(0=>’haha’,1=>’wow’),’b'=>1),想要删除a中value为haha的子项:

$coll->update(

array(’b'=>1),

array(’$pull=>array(’a'=>’haha’)),

)

结果为: array(’a'=>array(0=>’wow’),’b'=>1)

$pullAll

与$pull类似,只是可以删除一组符合条件的记录。

4.获取单条数据

$result = $table->findOne(array("name"=>"name5"),array('age'));
print_r($result); //单条数据 固定字段
多条数据
$result = $table->find(array(),array("name"));


5.分页查询记录

$result = $table->find();
$result = $result->sort(array("age"=>1));
$result = $result->skip(2)->limit(3);
foreach($result as $val){
print_r($val);
}


6 显示数据库 显示表

show dbs
show tables
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: