MongoDB
项目介绍
MongoDB : 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
来源
知识点
- 数据库(Database)
- 集合(collection)
- 文档(Document)
关系型数据库
- 数据库(Database)
- 数据表(Table)
- 记录(Record)
使用步骤
- 建立数据库(lomaBlog)
- 建立数据集合(Posts,Categoties,Tags)
- 建立数据库(Post:("_id":"","_teile":""))
基本使用
- mongo命令行工具
- 新建删除数据库
$ mongo
> help
> exit
$ mongo
> show dbs; # 查看所有数据库
> use komablog; #使用 komablog 数据库
> show collections; # 查看当前数据库 所有集合(collections)
> db.creatCollection("posts"); #创建集合
> db.creatCollection("categories");
> db.creatCollection("tags");
> show collections;
> show dbs;
> db.stats(); #查看数据库状态
> db.dropDatabase(); #删除数据库
> show dbs;
MongoDB 操作集合(Collection)
$ mongo
> show dbs;
> use komablog;
> show collections;
> db.createCollection("users"); #创建集合users
> show collections;
> db.users.renameCollection("staff"); #修改集合users名为staff
> show collections;
> db.staff.drop();
> show collections;
> db.dropDatabase(); #删除数据库
MongoDB 操作文档(Document)
$ mongo
> use komablog;
> show collections;
> db.createCollection("posts");
> db.posts.insert( # 在当前数据库下的posts文档下新增一条数据
... {
... title: "我的第一篇博客",
... content: "已经开始写博客了,太激动了。"
... }
... );
> show collections;
> db.posts.find(); # 显示当前数据库下的posts文档下的所有数据
> db.posts.insert(
... {
... title: "我的第二篇博客",
... content: "写点什么好呢?",
... tag: ["未分类"]
... }
... );
> db.posts.find();
> for(var i = 3; i <=10; i++ ) {
... db.posts.insert({
... title: "我的第" + i + "篇博客"
... });
... }
> db.posts.find();
> db.posts.count(); #统计当前数据库下posts文档的所有数据条数
> db.posts.remove({}); # 删除当前数据库下的posts文档的所有数据
> db.posts.count();
> db.posts.find();
MongoDB 带条件操作文档
# db.[collection_name].find({"":""})
# $gte, $gt, $lte, $lt (大于等于,大于,小于等于,小于,等于)
# $eq, $ne (等于,不等于)
# 正则表达式:/k/, /^k/
# db.[collection_name].distinct("field_name");
实战
$ mongo
> use komablog;
> db.posts.remove({}); # 删除所有数据
> db.posts.insert({title:"怪物猎人世界评测","rank":2,"tag":"game"});
> db.posts.insert({title:"纸片马里奥试玩体验","rank":1,"tag":"game"});
> db.posts.insert({title:"Utunbu16LTS的安装","rank":3,"tag":"it"});
> db.posts.insert({title:"信长之野望大志销量突破10000","rank":4,"tag":"game"});
> db.posts.insert({title:"Ruby的开发效率真的很高吗","rank":7,"tag":"it"});
> db.posts.insert({title:"塞尔达传说最近出了DLC","rank":4,"tag":"game"});
> db.posts.find({"tag": "game"}); #取出tag是game的数据
> db.posts.find({"rank": {$gte: 4}}); #取出rank是≥4的数据
> db.posts.find({"rank": {$gt: 4}});#取出rank是>4的数据
> db.posts.find({"rank": {$lte: 4}});#取出rank是≤4的数据
> db.posts.find({"rank": {$lt: 4}});#取出rank是<的数据
> db.posts.find({"title": /u/}); #取出文章标题带u的数据
> db.posts.find({"title": /^R/}); #取出文章标题R开头的数据
> db.posts.find({"title": /^U/});#取出文章标题U开头的数据
> db.posts.distinct("tag");#取出文章tag
复杂条件查询
# db.[collection_name].find({"":"", "":""}) (多个条件)
# db.[collection_name].find({$or:[{...},{...}]}); (与或非)
# db.[collection_name].find({"": {$in: [...]}}); (in查询)
# db.[collection_name].find({"": {$exists: true}});
实战
$ mongo
> use komablog;
> db.posts.find();
> db.posts.find({"title": /u/, "rank":{$gte:5} });# 标题带u并且rank大于等于5的数据
> db.posts.find({$or: [{"title": /u/}, {"rank":{$gte:4}}] });# 标题带u或者rank大于等于4的数据
> db.posts.find({"rank": {$in: [3,4]} }); # 排名为3和4的数据
> db.posts.insert({ "title":"惊!骑士发生重大交易", "istop": true });
> db.posts.find({"istop": {$exists: true} }); # 取出 存在istop的数据
指定字段取出
db.[collection_name].find({},{field1:true,field2:1});
find 第一个参数为条件,第二个参数为要取出的字段(true,1是相同的意思)
实战
$ mongo
> use komablog;
> db.posts.find();
> db.posts.find({}, {title:true, rank:1}); #指定title和rank 显示(默认抽出id)
> db.posts.find({}, {title:true, rank:1, _id:0}); #不抽出id
文档的方法
知识点
- sort() 排序
- limit() 分页
- skip() 跳过
实战
$ mongo
> use komablog;
> db.posts.find();
> db.posts.find({},{_id:0}).sort({rank:1}); #按照rank 升序排序
> db.posts.find({},{_id:0}).sort({rank:-1}); #按照rank 降序排序
> db.posts.find({},{_id:0}).limit(3); #按照默认的顺序抽出前三条
> db.posts.find({},{_id:0}).sort({rank:-1}).limit(3);##按照rank 降序排序取前三条
> db.posts.findOne({},{_id:0}); #只抽出一条数据(db.posts.find({},{_id:0}).limit(1);)
> db.posts.find({},{_id:0}).limit(3);#按照默认的顺序抽出前三条
> db.posts.find({},{_id:0}).skip(3).limit(3); #跳过前三条(1-3),取三条数据(4-6)
文档更新(update)
- update(<filter>,<update>,<options>)
- (参数: 过滤器(条件),更新字段的详细,更新行为)
$ mongo
> use komablog;
> db.posts.findOne({"title":"怪物猎人世界评测"});
> db.posts.update({"title":"怪物猎人世界评测"}, {$set: {"rank": 10} }); #修改 title为怪物猎人世界评测 的rank 为10
> db.posts.find();
> db.posts.update({"title":"怪物猎人世界评测"}, {"rank": 99}); #删除本条数据的其他字段只保留_id和rank:99
> db.posts.find();
> db.posts.update({"tag":"it"}, {$set: {"rank": 50}}); #只更新查询到的tag为it的第一条数据的rank
> db.posts.find();
> db.posts.update({"tag":"it"}, {$set: {"rank": 60}}, {multi: true}); #更新全部tag为it的第一条数据的rank
> db.posts.find();
特殊函数
# $inc:递加
# $mul:相乘
# $rename:改名
# $set:新增or修改
# $unset:字段删除
实战
$ mongo
> use komablog;
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$inc: {rank: 1}}); #+1
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$mul: {rank: 2}}); #*2
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$rename: {"rank": "score"}}); #字段改名为score
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$set: {"istop": true}}); #删除字段istop
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$unset: {"istop": true}}); #删除字段istop
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
文档的特殊更新
- upsert:有则更新,无则追加
- remove:条件删除数据
实战
$ mongo
> use komablog;
> db.posts.find({}, {_id:0});
> db.posts.update({title:"其实创造比大志好玩"}, {title:"其实创造比大志好玩", "rank":5,"tag":"game"});
> db.posts.find({}, {_id:0});
> db.posts.update({title:"其实创造比大志好玩"}, {title:"其实创造比大志好玩", "rank":5,"tag":"game"}, {upsert:true});
> db.posts.find({}, {_id:0});
> db.posts.update({title:"其实创造比大志好玩"}, {title:"其实创造比大志好玩", "rank":7,"tag":"game"}, {upsert:true});
> db.posts.find({}, {_id:0});
> db.posts.remove({title:"其实创造比大志好玩"});
> db.posts.find({}, {_id:0});
使用索引
- getIndexes()
- createIndex({...}, {...})
- dropIndex({...})
实战
$ mongo
> use komablog;
> db.posts.getIndexes();
> db.posts.createIndex({rank:-1});
> db.posts.getIndexes();
> db.posts.dropIndex({rank:-1});
> db.posts.getIndexes();
> db.posts.createIndex({title:1}, {unique:true});
> db.posts.getIndexes();
> db.posts.find({}, {_id:0});
> db.posts.insert({title:"怪物猎人世界评测"});
备份和恢复
- mongodump
- mongorestore
实战
$ mongo
> show dbs;
> use komablog;
> db.posts.find({}, {_id:0});
> exit
$ mkdir dbbak
$ cd dbbak
$ mongodump -d komablog
$ ls
$ mongo komablog
> db.posts.find({}, {_id:0});
> db.posts.remove({});
> db.posts.find({}, {_id:0});
> exit
$ mongorestore --drop
$ mongo komablog
> db.posts.find({}, {_id:0});
> exit
$ mongodump --help