mongodb总结

安装

mongodb服务:

sudo service mongod/mongodb start

sudo service mongod/mongodb stop

sudo service mongod/mongodb restart

配置文件路径 /etc/mongod.conf|mongodb.conf

链接:

mongo

mongo -h ip:port

mongo --host ip --port port

mongodb的操作:

数据库:

    show dbs  查看数据库     

    db        查看当前数据库

    use dbname  切换数据库

    db.dropDatabase()  删除当前数据库

    db.stats()

集合:

    db.createCollecrion('colname',属性)

    db.createCollecrion('colname')

    db.createCollection('colname',{capped:true,size:字节大小,max:最大文档数量})

    db.colname.drop()

增:

db.colname.insert(docment)

db.colname.insert([docment,docment,...])

db.colname.insertOne(docment)

db.colname.insertMany([docment,docment,...])

删除:

db.colname.remove({})

db.colname.remove({条件})

db.colname.remove({条件},1) -> db.colname.remove({条件},{justOne:true})

修改:

更新文档中的某些键

db.colname.update({条件},{$set:{键:值}})

全文档更新(如果没找到,则作为一条新的数据插入)

db.colname.update({条件},{键:值})

save

case1:假如我们要更新的文档——id存在则修改

case2:假如我们要更新的文档——id不存在,则作为新的文档插入

db.colname.save({_id:'',键:值,键:值.....})

查:

db.colname.find()  ->  db.colname.find({})

db.colname.find({条件}) -> db.colname.find({age:20,name:'xxx'})

限制查询:limit

db.colname.find({条件}).limit(num) -> db.colname.find({age:20,name:'xxx'}).limit(3)

跳过:skip

db.colname.find({条件}).skip(num)

save结合使用:

db.colname.find({条件}).skip(num).limit(num)

排序:sort [1:升序,-1:降序]

db.colname.find({条件}).sort({键:方向})

投影: project(0:不显示,1:显示)

db.colname.find({},{字段:1,字段:1,字段:0})

db.colname.find({},{字段:0})

去重:distinct

db.colname.distinct('键',{条件}}) -> db.colname.distinct('age',{name:'xxx'})

统计:count()

db.colname.find().count()

db.colname.count({条件}) -> db.colname.find({条件}).count()

返回所有键位什么什么的类型的文档 type

db.colname.find({键:{$type:'类型(string,int)'}})

比较运算符

$lt 小于 -> db.colname.find({salary:{$lt:10000}}).count()

$lte 小于等于 -> db.colname.find({salary:{$lte:10000}}).count()

$gt 大于 

$gte 大于等于

$ne 不等于

逻辑运算符

$or -> db.colname.find({$or:[{salary:{$gt:10000}},{name:'李明'}]})

范围运算符

$in -> db.colname.find({键:{$in:[19,20,23]}})

$nin -> db.colname.find({age:{$nin:{19,20,23}}})

正则查询:(必须是字符串)

db.colname.find({name:/^李.*?/})

db.colname.find({name:$regex:'^李.*?'})

自定义查询:

db.colname.find({$where:function(){reture this.name=='李明'}})

db.colname.find({$where:function(){reture this.age > 20}})

聚合操作:

管道:

$group (分组)

统计班级人数: 

-> db.colname.aggregate([{$group:{_id:'$class',count:{$sum:1}}])

班级的平均年龄:

-> db.colname.aggregate([{$group:{_id:'$class',avgage:{$avg:'$age'}}])

返回班级的最大年龄,最小年龄

db.colname.aggregate([{$group:{_id:'$class',maxage:{$max:'$age'}}])

db.colname.aggregate([{$group:{_id:'$class',maxage:{$min:'$age'}}])

$project (只返回年龄和性别)

db.colname.aggregate([{$project:{age:1,gender:1,_id:0}}])

$match (返回年龄在大于50,小于100)

db.colname.aggregate([{$match:{age:{$gt:50,$lt:100}}}])

$skip与$limit限制查询

db.colname.aggregate([{$match:{age:{$gt:30}}},{$limit:3}])

db.colname.aggregate([{$match:{age:{$gt:30}}},{$skip:3}])

db.colname.aggregate([{$match:{age:{$gt:30}}},{$skip:3},{$limit:3}])

$unwind:将文档中的键对应的数组,拆分程单条独立的数据

db.colname.aggregate([{$unwind:'$tags'}])

$sort 排序 (返回年龄在大于50,小于100,降序排序)

db.colname.aggregate([{$match:{age{$gt:50,$lt:100}}},{$sort:{age:-1}}])

(返回年龄在大于50,小于100,升序排序)

db.colname.aggregate([{$match:{age{$gt:50,$lt:100}}},{$sort:{age:1}}])

聚合函数:

$sum

-> db.colname.aggregate([{$group:{_id:'$class',count:{$sum:1}}])

$avg

-> db.colname.aggregate([{$group:{_id:'$class',avgage:{$avg:'$age'}}])

$min

-> db.colname.aggregate([{$group:{_id:'$class',maxage:{$min:'$age'}}])

$push:

根据班级进行分组,返回班级下所有的搬家同学的姓名

-> db.colname.aggregate(pP$group:{_id:'$class_',names:{$push:'$name'},age:{$push:'$age'}})

$last:

返回接总的最后一个name

db.colname.aggregate([{$group:{_id:'null',last:{$last:'$name'}}}])

$first:

返回集合总的第一个name

db.colname.aggregate([{$group:{_id:'null',first:{$first:'$name'}}}])

索引:

_id索引:这个在插入文档时会自动创建

普通索引:

    单键索引:

        -> db.colname.createIndex({'索引键':方向})

    复合索引:

        -> db.colname.createIndex({'索引键':方向,'索引键':'方向'...})

子文档索引:

{

    class:'1804',

    student:{

        name:'李明',

        age:20,

        email:'[email protected]'

        adress:'北京'

    }

}

db.colname.createIndex({'student.name:1,'student.email:-1'})

使用 db.colname.find({student.name:'李明','student.email':'[email protected]'})

数组索引:

db.colname.createIndex({tags:1})

全文索引:

{

    'content':'abc 123 李明 1804班'

}

db.colname.createIndex({content:'text'...})

使用

db.colname.find({$text:{$search:'关键词'}})

属性:

backgroud 在后台创建索引

unique 唯一索引

name 给索引起一个名称

sparse 稀疏索引(if set 了这个属性,文档中如果含有这个索引键,那么创建索引,else不创建)

TTL expireAfterSeconds 秒: 该属性设置文档在集合中存活的时间,超时,删除

注意:我们直接插入一个时间,会跟文档中真正插入的时间,相差8小时

TTL补充:

    _id 不能设置为日期索引

    不能将已创建的索引直接修改位时间索引,只能删除,重新创建

    TTL 不能是符合索引

删除索引

db.colname.dropIndex('索引名')

db.colname.dropIndexs()

查看集合中的所有索引

db.colname.getIndexs()

查看集合中的索引的总大小

db.colname.totalIndexSize()

强制索引

db.colname.find({条件}).hint('索引名')

重建索引

db.colname.reIndex()

建立索引的注意事项、优点、缺点:

优点:相当于创建了一个目录,能够提高查找的效率

缺点:1.对于插入、删除、修改数据会变慢,因为在做插入、删除、修改数据的时候,索引也会随之变化

这样会降低效率 2.创建索引会产生额外的数据,增加我们对硬件的要求,会占额外占用内存

注意事项:

1.尽量减少创建不必要的索引

2.经常变动的键不必要创建索引

3.不会成为查询条件的值不需要创建索引

4.mongodb集合中最大的索引个数不能超过64个,

索引的名称不能超过128个字符,符合索引最大只能有31字段

5.不能命中索引的情况:$in $nin 范围运算符,以及比较运算符...

6.mongodb中索引放在内存中,必须确保索引的大小不会超过内存,

如果超过内存最大限制,mongodb会自动删除一些索引

创建用户:

普通用户、超级管理员

创建超级管理员

root:

read:

readwrite

use admin

db.createUser({

    'user':'username',

    'pwd':'password',

    'roles':[{'role':'root',db:'admin'}]

})

打开mongodb的安全设置

sudo vim /etc/mongod.conf

高版本

security:

authorization:enabled

或者:

1. sudo vim /etc/mongodb.conf

低版本

auth=true

2.修改完毕之后重置:sudo service mongodb restart

3.使用超管登录

mongo -u 用户名 -p 密码 --authenticationDatabase 'admin'

创建一个普通用户

use dbnamedb.createUser({

    'user':'username',

    'pwd':'password',

    'roles':[{'role':'readWrite',db:'dbname'}]

})

mongo -u 用户名 -p 密码 --authenticationDatabase'dbname'

修改用户信息

修改密码

db.updateUser('username',{pwd:'newpassword'})

修改用户名

db.updateUser('username',{user:'newusername'})

删除权限

db.revokeRolesFromUser('username',[{role:'权限',db:'dbname'}])

添加权限

db.grantRolesToUser('username',[{role:'权限',db:'dbname'}])

删除用户

db.dropUser('username)

方式二

use admin

db.sysem.users.remove({user:'username'})

查看所有的用户

use admin

db.system.users.find()

mongodb数据备份

mongodump -h 127.0.0.1:27017(本地可忽略) -d dbname -o 备份文件的路径

mongodump备份数据库下的集合

mongodump -h 127.0.0.1:27017(本地可忽略) -d dbname colname -o 备份文件的路径

备份所有的数据库

mongodump -h 127.0.0.1:27017(本地可忽略) -o 备份文件的路径

恢复数据库

mongorestore -h 127.0.0.1:27017(本地可忽略) -d dbname --dir 备份文件的路径

恢复数据下的集合

mongorestore -h 127.0.0.1:27017(本地可忽略) -d dbname colname --dir 备份文件的路径

恢复所有的数据库

mongorestore -h 127.0.0.1:27017(本地可忽略) --dir 备份文件的路径

数据的导出(json、csv)

导出json数据

mongoexport -d dbname -c colname -o ~/桌面/dump/名称.josn --type json、csv

导出csv数据

mongoexport -d dbname -c colname -o ~/桌面/dump/名称.csv --type csv -f '键名,键名...'

导入数据(json、csv)

导入json数据

mongoimport -d dbname-c colname --file ~/桌面/dump/名称.json --type json

导入csv数据

mongoimport -d dbname -c colname --file ~/桌面/dump/名称.csv --type csv - filed'键名,键名...'

mongodb状态检测

mongostat

mongotop

副本集

目的:

1.防止数据灾害

2.实时备份,实现主从节点数据一致性

3.读写分离

4.无诺机行为

5.分担主节点的压力

缺点:具有中心化,所有的增删改操作都需要在主节点完成,

对主节点的压力大,对主机的性能要求较高

如果实现副本集?

开始mongodb服务(至少俩个)

mongod --bind_ip ip --port port --dbpath 数据存放的路径 --replSet res0

...

链接mongo服务

mongo -- host ip --port port

确定主节点

rs.initiate()

添加从节点

rs.add('ip:port')

激活从节点

rs.slaveOk()

你可能感兴趣的:(mongodb总结)