mongodb和php的用法详解
时间:2022-07-27
本文章向大家介绍mongodb和php的用法详解,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Mognodb数据库连接.
默认格式
$m = new Mongo();
//这里采用默认连接本机的27017端口,当然也可以连接远程主机如 192.168.0.4:27017,如果端口是27017,端口可以省略。
标准连接
$m = new Mongo("mongodb://${username}:${password}@localhost");
实例:
$m = new Mongo("mongodb://127.0.0.1:27017/admin:admin");
数据库的用户名和密码都是admin
数据库操作
插入数据
<?php
//这里采用默认连接本机的27017端口,当然你也可以连接远程主机如192.168.0.4:27017
//如果端口是27017,端口可以省略
$m = new Mongo("mongodb://127.0.0.1:27017/admin:admin");
//选择comedy数据库,如果以前没该数据库会自动创建,也可以用$m- selectDB("comedy");
$db = $m- comedy;
//选择comedy里面的collection集合,相当于RDBMS里面的表,也可以使用
$collection = $db- collection;
$db- selectCollection("collection");
/*********添加一个元素**************/
$obj = array("title" = "php1", "author" = "Bill Watterson");
//将$obj 添加到$collection 集合中
$collection- insert($obj);
/*********添加另一个元素**************/
$obj = array("title" = "huaibei", "online" = true);
$collection- insert($obj);
//$query = array("title" = "huaibei");
$query = array( "_id" = $obj['_id'] );
$cursor = $collection- find($query);
//遍历所有集合中的文档
foreach ($cursor as $obj) {
echo $obj["title"] . "n";
echo $obj["_id"] . "n";
}
//断开MongoDB连接
$m- close();
带条件的查询
mysql: id = 123
mongo: array(‘id'= 123)
mysql: name link '%bar%'
mongo: array(‘name' = new MongoRegex(‘/.*bar.*/i'))
mysql: where id 10
mongo: array(‘id' = array(‘$gt' = 10))
mysql: where id = 10
mongo: array(‘id' = array(‘$gte' = 10))
mysql: where id < 10
mongo: array(‘id' = array(‘$lt' = 10))
mysql: where id <= 10
mongo: array(‘id' = array(‘$lte' = 10))
mysql: where id 1 and id < 10
mongo: array(‘id' = array(‘$gt' = 1,'$lt' = 10))
mysql: where id < 10
mongo: array(‘id' = array(‘$ne' = 10))
mysql: where id in(123)
mongo: array(‘id' = array(‘$in' = array(1,2,3)))
mysql: where id not in(123)
mongo: array(‘id' = array(‘$nin' = array(1,2,3)))
mysql: where id = 2 or id = 9
mongo: array(‘id' = array(‘$or' = array(array(‘id'= 2),array(‘id'= 9))))
mysql: order by name asc
mongo: array(‘sort'= array(‘name'= 1))
mysql: order by name desc
mongo: array(‘sort'= array(‘name'= -1))
mysql: limit 0,2
mongo: array(‘limit'= array(‘offset'= 0,'rows'= 2))
mysql: select name,email
mongo: array(‘name','email')
mysql: select count(name)
mongo: array(‘COUNT') //注意:COUNT为大写
查询时,每个Object插入时都会自动生成一个独特的_id,它相当于RDBMS中的主键,用于查询时非常方便 (_id每一都不同,很像自动增加的id)
<?php
$param = array("name" = "joe");
$collection- insert($param);
$joe = $collection- findOne(array("_id" = $param['_id']));
print_R($joe);
$m- close();
返回结果:Array ( [_id] = MongoId Object ( [$id] = 4fd30e21870da83416000002 ) [name] = joe )
更改字段值
<?php
$sign = array("title" = 'php1');
$param = array("title" = 'php1','author'= 'test');
$joe = $collection- update($sign, $param);
删除一个数据库
$m - dropDB(“comedy”);
列出所有可用数据库
$m- listDBs(); //无返回值
创建一个MongoDB对象
<?php
$mo = new Mongo();
$db = new MongoDB($mo,'dbname');//通过创建方式获得一个MongoDB对象
删除当前DB
<?php
$db = $mo- dbname;
$db- drop();
获得当前数据库名
<?php
$db = $mo- dbname;
$db- _tostring();
选择想要的collection:
//A:
$mo = new Mongo();
$coll = $mo- dbname- collname;//获得一个collection对象
//B:
$db = $mo- selectDB('dbname');
$coll = $db- collname;
//C:
$db = $mo- dbname;
$coll = $db- collname;
//D:
$db = $mo- dbname;
$coll = $db- selectCollectoin('collname');//获得一个collection对象
插入数据(MongoCollection对象
$coll = $mo- db- foo;
$a = array('a'= 'b');
$options = array('safe'= true);
$rs =$coll- insert($a,$options);
删除数据库中的记录(MongoCollection对象)
$coll = $mo- db- coll;
$c = array('a'= 1,'s'= array('$lt'= 100));
$options = array('safe'= true);
$rs = $coll- remove($c,$options);
更新数据库中的记录(MongoCollection对象)
$coll = $mo- db- coll;
$c = array('a'= 1,'s'= array('$lt'= 100));
$newobj = array('e'= 'f','x'= 'y');
$options = array('safe'= true,'multiple'= true);
$rs = $coll- remove($c,$newobj,$options);
查询collection获得单条记录(MongoCollection类)
$coll = $mo- db- coll;
$query = array('s'= array('$lt'= 100));
$fields = array('a'= true,'b'= true);
$rs = $coll- findOne($query,$fields);
查询collection获得多条记录(MongoCollection类)
$coll = $mo- db- coll;
$query = array('s'= array('$lt'= 100));
$fields = array('a'= true,'b'= true);
$cursor = $coll- find($query,$fields);
//排序
$cursor- sort(array(‘字段'= -1));(-1倒序,1正序)
//跳过部分记录
$cursor- skip(100);跳过100行
//只显示部分记录
$cursor- limit(100);只显示100行
返回一个游标记录对象MongoCursor。
针对游标对象MongoCursor的操作(MongoCursor类)
$cursor = $coll- find($query,$fields);
while($cursor- hasNext()){
$r = $cursor- getNext();
var_dump($r);
}
//或者
$cursor = $coll- find($query,$fields);
foreache($cursor as $k= $v){
var_dump($v);
}
//或者
$cursor = $coll- find($query,$fields);
$array= iterator_to_array($cursor);
- Firefox内存释放重用漏洞高级利用(Pwn2Own2014、CVE-2014-1512)
- android 线程那点事
- android 向webview传值
- 用搜索神器Everything定位Webshell木马后门
- 终端图像处理系列 - OpenGL ES 2.0 - 3D基础(矩阵投影)
- XssHtml – 基于白名单的富文本XSS过滤类
- fireeyee解剖新型Android恶意软件
- WordPress系统暴力破解测试工具 – wpbf
- RecyclerView notifyItem闪烁的问题
- 独家: iOS是如何收集用户的地理信息的
- Hygieia 为何物?DevOps 利器也
- 汽车攻击离你很近:一分钟变成汽车黑客
- LIFX智能灯泡漏洞泄露WIFI密码
- android ViewPager+Fragment之懒加载
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 微信文章爬虫
- vue 随记(6):构建的艺术
- Centos7发布SpringBoot项目并后台运行
- k8s部署zookeeper集群
- dotnet 使用 SemaphoreSlim 可能的内存泄露
- WPF 绑定继承的样式提示 只能根据带有基类型 IFrameworkInputElement 的目标类型的 Style 样式
- 29.opengl高级光照-视差贴图
- SpringBoot集成Mybatis开启下划线格式的数据自动转换成小驼峰格式
- WPF 列表右键菜单比较符合 MVVM 的命令绑定方法
- Group Sample:一个简单有效的目标检测涨点Trick
- PyTorch版CenterNet数据加载解析
- WPF 使用 HandyControl 给 ListView 添加漂亮的表头效果
- kali2020 忘记密码
- 低比特量化之DoreFa-Net理论与实践
- 不用数组求多个数的最小值