PHP那些事儿

PHP操作mogodb入门

2019-06-25  本文已影响0人  栋公子

前言

mongodb是文档数据库,存贮的是文档(Bson->json的二进制化)

特点:内部引擎用js解析器,把文档存贮成bson结构,在查询时,转成为js对象并可以通过js语法操作

存贮方式为:在现有的磁盘之上,封装了gridfs 文件存贮系统,然后存贮一个个的json二进制对象(bson)

和传统型的数据库相比,不同点为:

传统型数据库,存贮的是结构化数据,定好了表结构,每一行的内容,必定是符合,列的个数一样。

在文档型数据库中,每一行的内容可能不一样。

比如:

在mysql中存贮的是这样的

id:3,name:wang,age:20

但是在mogo中,可能就不止这三个值了

id:4,name:li,sex:nan,hobby:cat //可以随意添加,每一行的都可以不一样

表下的每篇文档都可以有自己独特的结构,属性和值

文档数据库是反范式化的,

比如电影的影评,然后影评下面有回复,有点赞等等,都可以通过一篇文档即可完成,但是在mysql中最起码需要四张关联表

安装

下载地址:

https://www.mongodb.com

一般来说mongodb都是安装在Linux操作系统上的,但是我本机是mac系统,所以接下来的演示都是在mac上上演示的,但是操作系统本身和软件本身的操作并没有显著的差别,所以读者并不需要去担心,命令都是一样的,大可放心。

mac下载地址:

https://fastdl.mongodb.org/osx/mongodb-osx-ssl-x86_64-4.0.3.tgz

需要注意一点的是,解压之后就可以用了,本身就是编译好的。

文件介绍:

bsondum//二进制导出(导出bson)mongo//客户端mongod//服务端mongodump//导出(整体导出,二进制)mongoexport//导出容易识别的json文档或csv文档mongorestore//导入数据库(整体)mongos//路由器做集群的时候(数据库分片)mongostatmongotop//观察状态

启动mongo服务

./bin/mongod --dbpath /Applications/MAMP/mongodb/mongodatabase --logpath /Applications/MAMP/mongodb/mongolog/log.rtf --fork --port 27017

//解释

--dbpath 数据库目录

--logpath 日志存贮目录

--fork 后台运行

--port 端口

客户端链接服务端

./bin/mongo

ps:非常占用磁盘空间,所以读者在用的时候记得要让磁盘空间保持比较空闲,大概会占用3.5G左右,如果磁盘空间不足,那就加上选项 --smallfiles ,将会占用较小的空间,大概400M左右

操作数据库命令:

show dbs; //展示当前的所有数据库

use 数据库的名称 //切换到某个数据库

show tables; //展示当前的表

db.help() //查看所有的命令,帮助文档

如何创建数据库? mongodb的库都是隐式创建的,你可以use一个不存在的表,然后在该库下创建collection

既可创建数据库,什么叫collection,你可以把他理解为mysql的表

db.createCollection(name) //创建collection ,name 为collection 的名字 ,读者是不是很好奇,为啥没有创建字段呢?这就是mongo的特点,你不必拘泥于表结构,随便写入数据就可以了

db.shop.insert({name:'list',age:22}) //向数据库中插入数据 这里的shop 是collection 名字

db.shop.find() //查找数据

collection 也是隐式创建的 ,这一点需要声明

db.shop.drop() //删除collection

db.shop.remove() //删除整个collection,不建议使用这个命令

db.shop.remove({sn:'1'}) //删除 匹配的 sn 的行

remove第二个参数 justOne true /false true 只删除一行

db.shop.remove({sn:'1'},true) 只删除一行

db.shop.update({sn:1},{sn:2}) //新文档会直接替换旧的文档,其他参数不指定,将会被删除

db.shop.update({sn:1},{$set:{sn:2}}) //只会更改指定的字段,其他不影响

$unset 删除某个列

$rename 重命名某个列

$inc 增长某个列的值

//此处待增加,后续会增加,欢迎关注本专栏,及时收到内容

PHP操作mongo

PHP如果想要链接mongo,需要编译扩展

首先需要到官方网站去搜索扩展,我之前写过一篇文章专门介绍PHP如何编译扩展

PHP扩展(extensions),如果有兴趣的可以到我的这篇文章去看一下

好,废话少说,我们来安装mongo的扩展

第一步,到官网去,官网地址:

The PHP Extension Community Library

我下载的安装包,你们有需要的,可以自己去下载所需要的

http://pecl.php.net/get/mongodb-1.2.4.tgz

好,开始安装

tar zxvf mongodb-1.2.4.tgz

cd mongodb-1.2.4

phpize

./configure --with-php-config=/usr/local/php/bin/php-config

本来按照正常的逻辑是没有问题的,但是在编译的时候会出现如下报错

configure: error: Cannot find OpenSSL's <evp.h>

那么该如何解决呢?

好的,那么我们把问题自己研究一下?首先我们是在mac环境下的,好吧,根据网友提供的解题思路如下:

不得不说,网友提供的解题思路还是比较粗暴,不建议采取,我们就自己来解决一下问题吧。

那么,我们发现了什么呢?就是他在编译的时候指定了--with-openssl-dir这个,是不是我们也指定这个参数就好了呢,我们来试一下,首先找到本机安装的openssl地址

作为mac来说,执行一下命令就可以了

brew list openssl //这个命令会列出本机openssl的安装地址,复制一下就好了

那么在Linux操作系统中该如何操作呢,聪明的你已经知道吧,比如试一下find which where 命令

如果没有安装openssl该如何呢,

比如在centos 上可以执行一下命令

yum install openssl openssl-devel

然后再找安装位置,更多的需要自己去探索,如果你知道更多的方法,欢迎在下方留言,提供给更多的小伙伴

./configure --with-php-config=/usr/local/bin/php-config --with-openssl-dir=/usr/local/Cellar/openssl/1.0.2n/

这次就没有报任何错误了,好的,我们继续

make

make install

然后找到PHP.ini 文件加入以下一行

extension=mongodb.so

好的,完成.

记得重启php对于新的模块的支持

最后不要忘记执行

php  -m  //已确保扩展安装成功了

好的,扩展也加上了,服务端也也加上了,让我们开始PHP操作mongodb吧。

首先操作之前,容许我给大家放一个官网文档在这里镇住。需要说明的是,我这里只会给大家列出常用的操作,具体的操作,需要大家自行去文档查看,如果您对官方文档有不明白的,可以在下方给我留言。

http://php.net/manual/zh/mongo.core.php

首先是链接数据库

$mongodb = new new MongoClient(); //初始化一个类

$db = $mongodb->test; //选择一个数据库

$collection = $db->selectCollection('news');// 选择一个collection ,就是类比mysql的表

$ret  = $collection->findOne(); //查询一条数据

.......

$ret = $collection->find();//查询所有的数据

第二种查询,按照where 条件查询

比如在mysql中

select * from test where good_id=10;

在mongodb中这么写

$where = array('good_id'=>10);

$ret = $collection->find($where);

那我想查询大于呢?

select * from test where id>10;

在mongodb

$where = array(

  'id'=>array(

      '$gt'=>10

  )

);

$ret = $collection->find($where);

如果同时大于和小于呢?

select * from test where id>10 and id<100;

$where = array(

  'id'=>array(

    '$gt'=>10,

      '$lt'=>100

  )

);

$ret = $collection->find($where);

现在我想不查询所有的,只查询id

select id from test where id>10 and id<100;

$where = array(

  'id'=>array(

    '$gt'=>10,

      '$lt'=>100

  )

);

$fields = array('id');

$ret = $collection->find($where,$fields);

再放个文档镇场。

http://php.net/manual/zh/mongocollection.find.php

相关的操作可以看这里

mongodb排序操作实现

比如,在mysql中的排序sort 在mongodb是如何查询的

....

假设有一列数据,按照mysql的写法是

select * from test order by id desc;

就是按照ID的大小来排序,那么在mongodb需要这么写

$sort = array('id'=>-1);

$ret = $collection->find()->sort($sort);

上面是按照倒叙来排序的,如果是正序呢

$sort = array('id'=>1);

$ret = $collection->find()->sort($sort);

从上面读者就发现,正序的话,value就是1,倒叙的value就是-1

那我要是有两个条件呢?

比如mysql中的这个

select * from test order by id desc,name asc;

也就是先按照id倒叙排好之后,在按照name来正序排列

$sort = array('id'=>-1,'name'=>1);

$ret = $collection->find()->sort($sort);

好了,如果对mongodb相关的有任何疑问,可以关注本专栏,或者在下方给我留言,我会给予及时的解答。

上一篇下一篇

猜你喜欢

热点阅读