php对mongodb的扩展(初出茅庐)


Posted in PHP onNovember 11, 2012

我们的php mongodb也能做mysql、sqlserver能做的几乎所有功能,本文将详细介绍

一、操作符
操作符相信大家肯定都知道了,就是等于、大于、小于、不等于、大于等于、小于等于,但是在mongodb里不能直接使用这些操作符。在mongodb里的操作符是这样表示的:
(1) $gt > (大于)

 
(2) $lt

< (小于)

 
(3) $gte

>= (大于等于)
(4) $lt

<= (小于等于)


(5) $ne

!= (不等于) 
(6) $in

in (包含)


(7) $nin

not in (不包含)


(8) $exists

exist (字段是否存在) 
(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}})

噢!一口气写太多了,大家看太多也不易消化。今天就到这里吧,明天接着写php对mongodb的操作,尽请期待哦!不能再写了,不然的话明天会变熊猫。good night. have a good dream.
PHP 相关文章推荐
剖析 PHP 中的输出缓冲
Dec 21 PHP
实用函数3
Nov 08 PHP
PHP 文件上传功能实现代码
Jun 24 PHP
php中通过curl smtp发送邮件
Jun 05 PHP
php使用异或实现的加密解密实例
Sep 04 PHP
php抽象类使用要点与注意事项分析
Feb 09 PHP
PHP实现的蚂蚁爬杆路径算法代码
Dec 03 PHP
php连接oracle数据库的核心步骤
May 26 PHP
PHP中Notice错误常见解决方法
Apr 28 PHP
php生成条形码的图片的实例详解
Sep 13 PHP
PHP 中 var_export、print_r、var_dump 调试中的区别
Jun 19 PHP
浅析PHP7的多进程及实例源码
Apr 14 PHP
PHP面向对象——访问修饰符介绍
Nov 08 #PHP
PHP ? EasyUI DataGrid 资料存的方式介绍
Nov 07 #PHP
PHP ? EasyUI DataGrid 资料取的方式介绍
Nov 07 #PHP
PHP正确解析UTF-8字符串技巧应用
Nov 07 #PHP
nginx+php-fpm配置文件的组织结构介绍
Nov 07 #PHP
使用 PHPMAILER 发送邮件实例应用
Nov 07 #PHP
PHP数据集构建JSON格式及新数组的方法
Nov 07 #PHP
You might like
深入for,while,foreach遍历时间比较的详解
2013/06/08 PHP
php程序总是提示验证码输入有误解决方案
2015/01/07 PHP
Zend Studio使用技巧两则
2016/04/01 PHP
PHP数组函数array_multisort()用法实例分析
2016/04/02 PHP
PHP经典算法集锦【经典收藏】
2016/09/14 PHP
PHP字典树(Trie树)定义与实现方法示例
2017/10/09 PHP
快速解决PHP调用Word组件DCOM权限的问题
2017/12/27 PHP
PHP 实现缩略图
2021/03/09 PHP
让alert不出现弹窗的两种方法
2014/05/18 Javascript
JavaScript实现的双向跨域插件分享
2015/01/31 Javascript
浅谈使用MVC模式进行JavaScript程序开发
2015/11/10 Javascript
html5+javascript实现简单上传的注意细节
2016/04/18 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
微信小程序(六):列表上拉加载下拉刷新示例
2017/01/13 Javascript
js手机号4位显示空格,银行卡每4位显示空格效果
2017/03/23 Javascript
ES6新特性三: Generator(生成器)函数详解
2017/04/21 Javascript
jQuery UI 实例讲解 - 日期选择器(Datepicker)
2017/09/18 jQuery
layui表格checkbox选择全选样式及功能的实例
2018/03/07 Javascript
Node.js API详解之 net模块实例分析
2020/05/18 Javascript
Python中的localtime()方法使用详解
2015/05/22 Python
Linux上使用Python统计每天的键盘输入次数
2019/04/17 Python
Python入门Anaconda和Pycharm的安装和配置详解
2019/07/16 Python
Python facenet进行人脸识别测试过程解析
2019/08/16 Python
python基于opencv实现人脸识别
2021/01/04 Python
Armor Lux法国官方网站:水手服装、成衣和内衣
2020/05/26 全球购物
旅游管理实习自我鉴定
2013/09/29 职场文书
公务员总结性个人自我评价
2013/12/05 职场文书
教师自我评价范文
2013/12/16 职场文书
委托书样本
2014/04/02 职场文书
机关作风建设工作总结
2014/10/23 职场文书
2014年办公室个人工作总结
2014/11/12 职场文书
计划生育个人总结
2015/03/02 职场文书
护士长2015年终工作总结
2015/04/24 职场文书
大学生活委员竞选稿
2015/11/21 职场文书
导游词之无锡梅园
2019/11/28 职场文书
python pyhs2 的安装操作
2021/04/07 Python