mongodb和php的用法介绍(代码示例)
本篇文章给大家带来的内容是关于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);
本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的mongodb视频教程栏目!
以上是mongodb和php的用法介绍(代码示例)的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

在PHP8 中,match表达式是一种新的控制结构,用于根据表达式的值返回不同的结果。1)它类似于switch语句,但返回值而非执行语句块。2)match表达式使用严格比较(===),提升了安全性。3)它避免了switch语句中可能的break遗漏问题,增强了代码的简洁性和可读性。

在PHP中可以通过使用不可预测的令牌来有效防范CSRF攻击。具体方法包括:1.生成并在表单中嵌入CSRF令牌;2.在处理请求时验证令牌的有效性。

在PHP中,final关键字用于防止类被继承和方法被重写。1)标记类为final时,该类不能被继承。2)标记方法为final时,该方法不能被子类重写。使用final关键字可以确保代码的稳定性和安全性。

PHP中的...(splat)操作符用于函数参数和数组解包,提升代码简洁性和效率。1)函数参数解包:将数组元素作为参数传递给函数。2)数组解包:将一个数组解包到另一个数组中或作为函数参数。

PHP中的严格类型通过在文件顶部添加declare(strict_types=1);来启用。1)它强制对函数参数和返回值进行类型检查,防止隐式类型转换。2)使用严格类型可以提高代码的可靠性和可预测性,减少bug,提升可维护性和可读性。

Composer是PHP的依赖管理工具。使用Composer的核心步骤包括:1)在composer.json中声明依赖,如"stripe/stripe-php":"^7.0";2)运行composerinstall下载并配置依赖;3)通过composer.lock和autoload.php管理版本和自动加载。Composer简化了依赖管理,提升了项目效率和可维护性。

PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。
