前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mongodb和php的用法详解

mongodb和php的用法详解

作者头像
砸漏
发布2020-10-21 16:02:25
7930
发布2020-10-21 16:02:25
举报
文章被收录于专栏:恩蓝脚本

Mognodb数据库连接.

默认格式

代码语言:javascript
复制
$m = new Mongo();

//这里采用默认连接本机的27017端口,当然也可以连接远程主机如 192.168.0.4:27017,如果端口是27017,端口可以省略。

标准连接

代码语言:javascript
复制
$m = new Mongo("mongodb://${username}:${password}@localhost");

实例:

代码语言:javascript
复制
$m = new Mongo("mongodb://127.0.0.1:27017/admin:admin");

数据库的用户名和密码都是admin

数据库操作

插入数据

代码语言:javascript
复制
<?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();

带条件的查询

代码语言:javascript
复制
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)

代码语言:javascript
复制
<?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 )

更改字段值

代码语言:javascript
复制
<?php

$sign = array("title" =  'php1');

$param = array("title" =  'php1','author'= 'test');

$joe = $collection- update($sign, $param);

删除一个数据库

代码语言:javascript
复制
$m -  dropDB(“comedy”);

列出所有可用数据库

代码语言:javascript
复制
$m- listDBs();  //无返回值

创建一个MongoDB对象

代码语言:javascript
复制
<?php

$mo = new Mongo();

$db = new MongoDB($mo,'dbname');//通过创建方式获得一个MongoDB对象

删除当前DB

代码语言:javascript
复制
<?php

$db = $mo- dbname;

$db- drop();

获得当前数据库名

代码语言:javascript
复制
<?php

$db = $mo- dbname;

$db- _tostring();

选择想要的collection:

代码语言:javascript
复制
//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对象

代码语言:javascript
复制
$coll = $mo- db- foo;

$a = array('a'= 'b');

$options = array('safe'= true);

$rs =$coll- insert($a,$options);

删除数据库中的记录(MongoCollection对象)

代码语言:javascript
复制
$coll = $mo- db- coll;

$c = array('a'= 1,'s'= array('$lt'= 100));

$options = array('safe'= true);

$rs = $coll- remove($c,$options);

更新数据库中的记录(MongoCollection对象)

代码语言:javascript
复制
$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类)

代码语言:javascript
复制
$coll = $mo- db- coll;

$query = array('s'= array('$lt'= 100));

$fields = array('a'= true,'b'= true);

$rs = $coll- findOne($query,$fields);

查询collection获得多条记录(MongoCollection类)

代码语言:javascript
复制
$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类)

代码语言:javascript
复制
$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);
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档