前言
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相关的有任何疑问,可以关注本专栏,或者在下方给我留言,我会给予及时的解答。
网友评论