2021-02-05


MongoDB数据管理

查看集合show collections,或者使用show tables
如果集合不存在,直接插入数据,则mongodb会自动创建集合
在这里插入图片描述
更新
在这里插入图片描述
查看所有文档db.Account.find()
在这里插入图片描述
根据条件查询:db.Account.find({AccountID:1})
在这里插入图片描述
根据条件删除:db.Account.remove({AccountID:1})
在这里插入图片描述
删除所有文档,即删除集合:db.Account.drop()
在这里插入图片描述
先进入对应的库:use dbname
在这里插入图片描述
然后查看集合状态:db.printCollectionStats()

PHP连接MongoDB-mongodb.so

[root@localhost ~]# cd /usr/local/src/
[root@localhost src]# git clone https://github.com/mongodb/mongo-php-driver
在这里插入图片描述
如果没有git工具自行,yum install -y git 下载
[root@localhost src]# cd mongo-php-driver/
[root@localhost mongo-php-driver]# git submodule update --init
在这里插入图片描述
[root@localhost mongo-php-driver]# yum install -y php-devel
[root@localhost mongo-php-driver]# /usr/bin/phpize
在这里插入图片描述
[root@localhost mongo-php-driver]# ./configure --with-php-config=/usr/bin/php-config
[root@localhost mongo-php-driver]# make && make install
#vi /usr/local/php/etc/php.ini //增加 extension = mongodb.so
[root@localhost mongo-php-driver]# /usr/local/php/bin/php -m
**

MongoDB副本集

**

  • 早期版本使用master-slave,一主一从和MySQL类似,但slave在此架构中为只读,当主库宕机后,从库不能自动切换为主
  • 目前已经淘汰master-slave模式,改为副本集,这种模式下有一个主(primary),和多个从(secondary),只读。支持给它们设置权重,当主宕掉后,权重最高的从切换为主
  • 在此架构中还可以建立一个仲裁(arbiter)的角色,它只负责裁决,而不存储数据
  • 再此架构中读写数据都是在主上,要想实现负载均衡的目的需要手动指定读库的目标server
    **

MongoDB备份

**

  • 备份指定库
    mongodump --host 127.0.0.1 --port 20000 -d mydb -o /tmp/mongobak
    它会在/tmp/目录下面生成一个mydb的目录
  • 备份所有库
    mongodump --host 127.0.0.1 --port 20000 -o /tmp/mongobak/alldatabase
  • 指定备份集合
    mongodump --host 127.0.0.1 --port 20000 -d mydb -c c1 -o /tmp/mongobak/
    它依然会生成mydb目录,再在这目录下面生成两个文件
  • 导出集合为json文件
    mongoexport --host 127.0.0.1 --port 20000 -d mydb -c c1 -o /tmp/mydb2/1.json
    MongoDB恢复
    **

- 恢复所有库

**
mongorestore -h 127.0.0.1 --port 20000 --drop dir/ //其中dir是备份所有库的目录名字,其中–drop可选,意思是当恢复之前先把之前的数据删除,不建议使用

  • 恢复指定库
    mongorestore -d mydb dir/ //-d跟要恢复的库名字,dir就是该库备份时所在的目录
  • 恢复集合
    mongorestore -d mydb -c testc dir/mydb/testc.bson // -c后面跟要恢复的集合名字,dir是备份mydb库时生成文件所在路径,这里是一个bson文件的路径
  • 导入集合
    mongoimport -d mydb -c testc --file /tmp/testc.json****
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值