美文网首页PHP那些事儿
PHP操作mogodb入门

PHP操作mogodb入门

作者: 栋公子 | 来源:发表于2019-06-25 22:02 被阅读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相关的有任何疑问,可以关注本专栏,或者在下方给我留言,我会给予及时的解答。

    相关文章

      网友评论

        本文标题:PHP操作mogodb入门

        本文链接:https://www.haomeiwen.com/subject/jvrfcctx.html