1. 文章
  2. 文章详情

PHP操作mogodb入门

前言

MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。

MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

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

在mac上演示

mac下载地址:

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

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

PHP操作mogodb入门

文件介绍:

bsondum //二进制导出导出bson
mongo //客户端
mongod	//服务端
mongodump //导出整体导出二进制
mongoexport //导出容易识别的json文档或csv文档

mongorestore //导入数据库整体
mongos //路由器 做集群的时候数据库分片

mongostat mongotop //观察状态

启动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 

那么该如何解决呢?

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

PHP操作mogodb入门

那么,我们发现了什么呢?就是他在编译的时候指定了--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);

参考:https://zhuanlan.zhihu.com/p/48249494

发表评论

登录后才能评论

评论列表(0条)