您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

php对mongodb的扩展

2025/12/4 7:26:50发布15次查看
我们的php mongodb也能做mysql、sqlserver能做的几乎所有功能,本文将详细介绍
一、操作符 
操作符相信大家肯定都知道了,就是等于、大于、小于、不等于、大于等于、小于等于,但是在mongodb里不能直接使用这些操作符。在mongodb里的操作符是这样表示的: 
(1) $gt > (大于)  
(2) $lt< (小于) 
(3) $gte>= (大于等于) 
(4) $lt<= (小于等于)
(5) $ne!= (不等于) 
(6) $inin (包含)
(7) $ninnot in (不包含)
(8) $existsexist (字段是否存在) 
(9) $inc对一个数字字段field增加value
(10) $set就是相当于sql的set field = value
(11) $unset就是删除字段
(12) $push把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去
(13) $pushall同$push,只是一次可以追加多个值到一个数组字段内
(14) $addtoset增加一个值到数组内,而且只有当这个值不在数组内才增加。
(15) $pop删除最后一个值:{ $pop : { field : 1 } }删除第一个值:{ $pop : { field : -1 } }注意,只能删除一个值,也就是说只能用1或-1,而不能用2或-2来删除两条。mongodb 1.1及以后的版本才可以用
(16) $pull从数组field内删除一个等于value值
(17) $pullall同$pull,可以一次删除数组内的多个值
(18) $ 操作符是他自己的意思,代表按条件找出的数组里面某项他自己。这个比较坳口,就不说了。
二、curd 增、改、读、删
增加
复制代码 代码如下:
db.collection->insert({'name' => 'caleng', 'email' => 'admin#admin.com'});
是不是灰常简单呀,对就是这么简单,它没有字段的限制,你可以随意起名,并插入数据
修改 
复制代码 代码如下: 
db.collection.update( { count : { $gt : 1 } } , { $set : { test2 : ok} } ); 只更新了第一条大于1记录 
db.collection.update( { count : { $gt : 3 } } , { $set : { test2 : ok} },false,true ); 大于3的记录 全更新了 
db.collection.update( { count : { $gt : 4 } } , { $set : { test5 : ok} },true,false ); 大于4的记录 只加进去了第一条 
db.collection.update( { count : { $gt : 5 } } , { $set : { test5 : ok} },true,true ); 大于5的记录 全加进去
查询 
复制代码 代码如下: 
db.collection.find(array('name' => 'bailing'), array('email'=>'email@qq.com')) 
db.collection.findone(array('name' => 'bailing'), array('email''email@qq.com'))
大家可以看到查询我用了两种不同的写法,这是为什么,其实这跟做菜是一样的,放不同的调料,炒出的菜是不同的味道。下面给大家说一下,这两种调料的不同作用。 
findone()只返回一个文档对象,find()返回一个集合列表。 
也就是说比如,我们只想查某一条特定数据的详细信息的话,我们就可以用findone(); 
如果想查询某一组信息,比如说一个新闻列表的时候,我们就可以作用find(); 
那么我想大家这时一定会想到我想对这一个列表排序呢,no problem mongodb会为您全心全意服务 
复制代码 代码如下: 
db.collection.find().sort({age:1}); //按照age正序排列 
db.collection.find().sort({age:-1}); //按照age倒序排列 
db.collection.count(); //得到数据总数 
db.collection.limit(1); //取数据的开始位置 
db.collection.skip(10); //取数据的结束位置 
//这样我们就实现了一个取10条数据,并排序的操作。
删除 
删除有两个操作 remove()和drop() 
复制代码 代码如下: 
db.collection.remove({name,'jerry'}) //删除特定数据 
db.collection.drop() //删除集合内的所有数据
distinct操作 
复制代码 代码如下: 
db.user.distinct('name', {'age': {$lt : 20}})
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product