一、装包
[root@ip50 ~]# tar -zxf mongodb/mongodb-linux-x86_64-rhel70-3.6.3.tgz //解压安装包
[root@ip50 ~]# mkdir /usr/local/mongodb //创建主目录
[root@ip50 ~]# cp -r mongodb-linux-x86_64-rhel70-3.6.3/bin /usr/local/mongodb/ //将主程序拷贝到主目录
[root@ip50 ~]# cd /usr/local/mongodb/
[root@ip50 mongodb]# mkdir -p etc log data/db //创建工作目录
二、修改配置文件
[root@ip50 ~]# vim /usr/local/mongodb/etc/mongodb.conf
logpath=/usr/local/mongodb/log/mongodb.log
logappend=true //追加方式记录日志信息
dbpath=/usr/local/mongodb/data/db //数据库目录
fork=true //守护进程方式运行
三、启动、连接服务
[root@ip50 mongodb]# /usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf
[root@ip50 ~]# /usr/local/mongodb/bin/mongo
show dbs //显示已有的库
use admin //切换到admin库
show tables //查看当前库下有哪些表
exit //退出
四、停止服务,设置命令别名,查看文件信息
[root@ip50 ~]# /usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf --shutdown
[root@ip50 ~]# alias mstart="/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf"
[root@ip50 ~]# alias mstop="/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf --shutdown"
[root@ip50 ~]# vim /root/.bashrc
... ...
alias mstart="/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf"
alias mstop="/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/etc/mongodb.conf --shutdown"
... ...
五、修改访问服务的ip跟端口
[root@ip50 ~]# vim /usr/local/mongodb/etc/mongodb.conf
logpath=/usr/local/mongodb/log/mongodb.log
logappend=true
dbpath=/usr/local/mongodb/data/db
fork=true
bind_ip=192.168.4.50 //定义访问ip
port=27050 //定义端口
//修改之后,连接服务,需要指定ip跟端口
[root@ip50 ~]# /usr/local/mongodb/bin/mongo --host 192.168.4.50 --port 27050
查看、创建、切换、删除库
数据库名称规范
集合管理
集合命名规范
文档基本管理
创建集合,添加数据
[root@ip50 ~]# /usr/local/mongodb/bin/mongo --host 192.168.4.50 --port 27050
> db.t1.save({'name':'bob','age':21})
> show tables
t1
> db.t1.save({'school':'Qinghua','address':'beijing','tel':666})
> db.t1.find()
{ "_id" : ObjectId("5ce7963049efaff863716965"), "name" : "bob", "age" : 21 }
{ "_id" : ObjectId("5ce7967049efaff863716966"), "school" : "Qinghua", "address" : "beijing", "tel" : 666 }
> db.t1.drop() //删除集合
true
字符string/布尔bool/空null
字符串string
布尔bool
空null
> db.t2.save({name:"lucy",ruslt:null})
> db.t2.save({"gender":true,"height":false})
> db.t2.find()
{ "_id" : ObjectId("5ce7a64d49efaff86371696c"), "name" : "lucy", "ruslt" : null }
{ "_id" : ObjectId("5ce7a68549efaff86371696d"), "gender" : true, "height" : false }
数值/数组array
> db.t3.save({x:3.14,y:3.56})
> db.t3.save({z:NumberInt(55.55)})
> db.t3.save({w:NumberLong(66.66)}) //不允许存储浮点型数值
> db.t3.save({w:NumberLong(66)})
> db.t3.find()
{ "_id" : ObjectId("5ce7a8a249efaff86371696e"), "x" : 3.14, "y" : 3.56 }
{ "_id" : ObjectId("5ce7a8db49efaff86371696f"), "z" : 55 }
{ "_id" : ObjectId("5ce7a90249efaff863716970"), "w" : NumberLong(66) }
代码/日期/对象
> db.t4.save({name:"jack",birthday:new Date()})
> db.t4.save({lname:"php",phpCode:function(){/**/}})
> db.t4.save({w:ObjectId()})
> db.t4.find()
{ "_id" : ObjectId("5ce7ae0949efaff863716973"), "name" : "jack", "birthday" : ISODate("2019-05-24T08:40:41.060Z") }
{ "_id" : ObjectId("5ce7ae8649efaff863716974"), "lname" : "php", "phpcode" : { "code" : "function (){/**/}" } }
{ "_id" : ObjectId("5ce7af5449efaff863716976"), "w" : ObjectId("5ce7af5449efaff863716975") }
内嵌/正则表达式
> db.t5.save({"beida":{"worker":"hsy","tel":119,address:"beijing","people":10000},money:10000})
> db.t5.find()
{ "_id" : ObjectId("5ce7b2cb49efaff863716978"), "beida" : { "worker" : "hsy", "tel" : 119, "address" : "beijing", "people" : 10000 }, "money" : 10000 }
> db.t5.save({linenull:/^$/,linefirst:/^/})
> db.t5.find()
{ "_id" : ObjectId("5ce7b3c849efaff863716979"), "linenull" : /^$/, "linefirst" : /^/ }
数据导出
语法格式1
#mongoexport [--host IP地址 --port 端口] -d 库名 -c 集合名 -f 字段名1,字段名2 --type=csv > 目录名/文件名.csv
[root@ip50 ~]# /usr/local/mongodb/bin/mongoexport --host 192.168.4.50 --port 27050 -d userdb -c t2 -f name,ruslt --type=csv > /root/1.txt
[root@ip50 ~]# cat /root/1.txt
语法格式2
#mongoexport --host IP地址 --port 端口 -d 库名 -c 集合名 -q '{条件}' -f 字段名1,字段名2 --type=csv > 目录名/文件名.csv
[root@ip50 ~]# /usr/local/mongodb/bin/mongoexport --host 192.168.4.50 --port 27050 -d userdb -c t4 -q '{name:/.*jack.*/}' -f name,age --type=csv > /root/2.txt
[root@ip50 ~]# cat /root/2.txt
注意:导出为csv格式必须使用-f指定字段名列表,如果不指定–type,默认是json格式
语法格式3
# mongoexport [--host IP地址 --port 端口] -d 库名 -c 集合名 [-q '{条件}' -f 字段列表] --type=json > 目录名/文件名.json
[root@ip50 ~]# /usr/local/mongodb/bin/mongoexport --host 192.168.4.50 --port 27050 -d userdb -c t4 --type=json > /root/3.json
[root@ip50 ~]# cat /root/3.json
数据导入
语法格式1
#mongoimport --host IP地址 --port 端口 -d 库名 -c 集合名 --type=json 目录名/文件名.json
语法格式2
#mongoimport --host IP地址 --port 端口 -d 库名 -c 集合名 --type=csv [--headerline] [--drop] 目录名/文件名.csv
注:
导入etc写的passwd
[root@ip50 ~]# cp /etc/passwd /root/
[root@ip50 ~]# sed -i 's/:/,/g' /root/passwd
[root@ip50 ~]# sed -i '1iname,password,uid,gid,comment,homedir,shell' /root/passwd //第一行添加7个表头
导入到userdb库下的user集合里边
[root@ip50 ~]# /usr/local/mongodb/bin/mongoimport --host 192.168.4.50 --port 27050 -d userdb -c user --type=csv --headerline --drop /root/passwd
登录查看数据
[root@ip50 ~]# /usr/local/mongodb/bin/mongo --host 192.168.4.50 --port 27050
备份数据所有库到当前目录下的dump目录下
# mongodump [--host ip地址 --port 端口]
[root@ip50 ~]# /usr/local/mongodb/bin/mongodump --host 192.168.4.50 --port 27050
[root@ip50 ~]# ls dump/
备份时指定备份的库和备份目录
# mongodump [--host ip地址 --port 端口] -d 数据库名 -c 集合名 -o 目录
[root@ip50 ~]# mkdir /mybak
[root@ip50 ~]# /usr/local/mongodb/bin/mongodump --host 192.168.4.50 --port 27050 -d userdb -c user -o /mybak/
查看bson文件内容
# bsondump ./dump/bbs/t1.bson
[root@ip50 ~]# /usr/local/mongodb/bin/bsondump /mybak/userdb/user.bson
语法格式
#mongorestore --host ip地址 --port 端口 -d 数据库名 [-c 集合名] 备份目录名
将50上的备份文件拷贝到51上,在51上进行数据恢复
[root@ip51 ~]# /usr/local/mongodb/bin/mongorestore --host 192.168.4.51 --port 27051 -d userdb /root/mybak/userdb