PHP操作mogodb入门

前言

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351