MongoDB 基本操作语句及实例

快来打我* 2023-07-03 07:07 47阅读 0赞

MongoDB

项目介绍

MongoDB : 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

来源

小马视频

知识点

  • 数据库(Database)
  • 集合(collection)
  • 文档(Document)

关系型数据库

  • 数据库(Database)
  • 数据表(Table)
  • 记录(Record)

使用步骤

  1. 建立数据库(lomaBlog)
  2. 建立数据集合(Posts,Categoties,Tags)
  3. 建立数据库(Post:(“_id”:””,”_teile”:””))

基本使用

  • mongo命令行工具
  • 新建删除数据库
  1. $ mongo
  2. > help
  3. > exit
  4. $ mongo
  5. > show dbs; # 查看所有数据库
  6. > use komablog; #使用 komablog 数据库
  7. > show collections; # 查看当前数据库 所有集合(collections)
  8. > db.creatCollection("posts"); #创建集合
  9. > db.creatCollection("categories");
  10. > db.creatCollection("tags");
  11. > show collections;
  12. > show dbs;
  13. > db.stats(); #查看数据库状态
  14. > db.dropDatabase(); #删除数据库
  15. > show dbs;

MongoDB 操作集合(Collection)

  1. $ mongo
  2. > show dbs;
  3. > use komablog;
  4. > show collections;
  5. > db.createCollection("users"); #创建集合users
  6. > show collections;
  7. > db.users.renameCollection("staff"); #修改集合users名为staff
  8. > show collections;
  9. > db.staff.drop();
  10. > show collections;
  11. > db.dropDatabase(); #删除数据库

MongoDB 操作文档(Document)

  1. $ mongo
  2. > use komablog;
  3. > show collections;
  4. > db.createCollection("posts");
  5. > db.posts.insert( # 在当前数据库下的posts文档下新增一条数据
  6. ... {
  7. ... title: "我的第一篇博客",
  8. ... content: "已经开始写博客了,太激动了。"
  9. ... }
  10. ... );
  11. > show collections;
  12. > db.posts.find(); # 显示当前数据库下的posts文档下的所有数据
  13. > db.posts.insert(
  14. ... {
  15. ... title: "我的第二篇博客",
  16. ... content: "写点什么好呢?",
  17. ... tag: ["未分类"]
  18. ... }
  19. ... );
  20. > db.posts.find();
  21. > for(var i = 3; i <=10; i++ ) {
  22. ... db.posts.insert({
  23. ... title: "我的第" + i + "篇博客"
  24. ... });
  25. ... }
  26. > db.posts.find();
  27. > db.posts.count(); #统计当前数据库下posts文档的所有数据条数
  28. > db.posts.remove({}); # 删除当前数据库下的posts文档的所有数据
  29. > db.posts.count();
  30. > db.posts.find();

MongoDB 带条件操作文档

  1. # db.[collection_name].find({"":""})
  2. # $gte, $gt, $lte, $lt (大于等于,大于,小于等于,小于,等于)
  3. # $eq, $ne (等于,不等于)
  4. # 正则表达式:/k/, /^k/
  5. # db.[collection_name].distinct("field_name");

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.remove({}); # 删除所有数据
  4. > db.posts.insert({title:"怪物猎人世界评测","rank":2,"tag":"game"});
  5. > db.posts.insert({title:"纸片马里奥试玩体验","rank":1,"tag":"game"});
  6. > db.posts.insert({title:"Utunbu16LTS的安装","rank":3,"tag":"it"});
  7. > db.posts.insert({title:"信长之野望大志销量突破10000","rank":4,"tag":"game"});
  8. > db.posts.insert({title:"Ruby的开发效率真的很高吗","rank":7,"tag":"it"});
  9. > db.posts.insert({title:"塞尔达传说最近出了DLC","rank":4,"tag":"game"});
  10. > db.posts.find({"tag": "game"}); #取出tag是game的数据
  11. > db.posts.find({"rank": {$gte: 4}}); #取出rank是≥4的数据
  12. > db.posts.find({"rank": {$gt: 4}});#取出rank是>4的数据
  13. > db.posts.find({"rank": {$lte: 4}});#取出rank是≤4的数据
  14. > db.posts.find({"rank": {$lt: 4}});#取出rank是<的数据
  15. > db.posts.find({"title": /u/}); #取出文章标题带u的数据
  16. > db.posts.find({"title": /^R/}); #取出文章标题R开头的数据
  17. > db.posts.find({"title": /^U/});#取出文章标题U开头的数据
  18. > db.posts.distinct("tag");#取出文章tag

复杂条件查询

  1. # db.[collection_name].find({"":"", "":""}) (多个条件)
  2. # db.[collection_name].find({$or:[{...},{...}]}); (与或非)
  3. # db.[collection_name].find({"": {$in: [...]}}); (in查询)
  4. # db.[collection_name].find({"": {$exists: true}});

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.find();
  4. > db.posts.find({"title": /u/, "rank":{$gte:5} });# 标题带u并且rank大于等于5的数据
  5. > db.posts.find({$or: [{"title": /u/}, {"rank":{$gte:4}}] });# 标题带u或者rank大于等于4的数据
  6. > db.posts.find({"rank": {$in: [3,4]} }); # 排名为3和4的数据
  7. > db.posts.insert({ "title":"惊!骑士发生重大交易", "istop": true });
  8. > db.posts.find({"istop": {$exists: true} }); # 取出 存在istop的数据

指定字段取出

  1. db.[collection_name].find({},{field1:true,field2:1});
  2. find 第一个参数为条件,第二个参数为要取出的字段(true,1是相同的意思)

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.find();
  4. > db.posts.find({}, {title:true, rank:1}); #指定title和rank 显示(默认抽出id)
  5. > db.posts.find({}, {title:true, rank:1, _id:0}); #不抽出id

文档的方法

知识点

  • sort() 排序
  • limit() 分页
  • skip() 跳过

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.find();
  4. > db.posts.find({},{_id:0}).sort({rank:1}); #按照rank 升序排序
  5. > db.posts.find({},{_id:0}).sort({rank:-1}); #按照rank 降序排序
  6. > db.posts.find({},{_id:0}).limit(3); #按照默认的顺序抽出前三条
  7. > db.posts.find({},{_id:0}).sort({rank:-1}).limit(3);##按照rank 降序排序取前三条
  8. > db.posts.findOne({},{_id:0}); #只抽出一条数据(db.posts.find({},{_id:0}).limit(1);)
  9. > db.posts.find({},{_id:0}).limit(3);#按照默认的顺序抽出前三条
  10. > db.posts.find({},{_id:0}).skip(3).limit(3); #跳过前三条(1-3),取三条数据(4-6)

文档更新(update)

  • update(,,)
  • (参数: 过滤器(条件),更新字段的详细,更新行为)
  1. $ mongo
  2. > use komablog;
  3. > db.posts.findOne({"title":"怪物猎人世界评测"});
  4. > db.posts.update({"title":"怪物猎人世界评测"}, {$set: {"rank": 10} }); #修改 title为怪物猎人世界评测 的rank 为10
  5. > db.posts.find();
  6. > db.posts.update({"title":"怪物猎人世界评测"}, {"rank": 99}); #删除本条数据的其他字段只保留_id和rank:99
  7. > db.posts.find();
  8. > db.posts.update({"tag":"it"}, {$set: {"rank": 50}}); #只更新查询到的tag为it的第一条数据的rank
  9. > db.posts.find();
  10. > db.posts.update({"tag":"it"}, {$set: {"rank": 60}}, {multi: true}); #更新全部tag为it的第一条数据的rank
  11. > db.posts.find();

特殊函数

  1. # $inc:递加
  2. # $mul:相乘
  3. # $rename:改名
  4. # $set:新增or修改
  5. # $unset:字段删除

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
  4. > db.posts.update({title:"怪物猎人世界评测"}, {$inc: {rank: 1}}); #+1
  5. > db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
  6. > db.posts.update({title:"怪物猎人世界评测"}, {$mul: {rank: 2}}); #*2
  7. > db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
  8. > db.posts.update({title:"怪物猎人世界评测"}, {$rename: {"rank": "score"}}); #字段改名为score
  9. > db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
  10. > db.posts.update({title:"怪物猎人世界评测"}, {$set: {"istop": true}}); #删除字段istop
  11. > db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
  12. > db.posts.update({title:"怪物猎人世界评测"}, {$unset: {"istop": true}}); #删除字段istop
  13. > db.posts.find({title:"怪物猎人世界评测"}, {_id:0});

文档的特殊更新

  • upsert:有则更新,无则追加
  • remove:条件删除数据

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.find({}, {_id:0});
  4. > db.posts.update({title:"其实创造比大志好玩"}, {title:"其实创造比大志好玩", "rank":5,"tag":"game"});
  5. > db.posts.find({}, {_id:0});
  6. > db.posts.update({title:"其实创造比大志好玩"}, {title:"其实创造比大志好玩", "rank":5,"tag":"game"}, {upsert:true});
  7. > db.posts.find({}, {_id:0});
  8. > db.posts.update({title:"其实创造比大志好玩"}, {title:"其实创造比大志好玩", "rank":7,"tag":"game"}, {upsert:true});
  9. > db.posts.find({}, {_id:0});
  10. > db.posts.remove({title:"其实创造比大志好玩"});
  11. > db.posts.find({}, {_id:0});

使用索引

  • getIndexes()
  • createIndex({…}, {…})
  • dropIndex({…})

实战

  1. $ mongo
  2. > use komablog;
  3. > db.posts.getIndexes();
  4. > db.posts.createIndex({rank:-1});
  5. > db.posts.getIndexes();
  6. > db.posts.dropIndex({rank:-1});
  7. > db.posts.getIndexes();
  8. > db.posts.createIndex({title:1}, {unique:true});
  9. > db.posts.getIndexes();
  10. > db.posts.find({}, {_id:0});
  11. > db.posts.insert({title:"怪物猎人世界评测"});

备份和恢复

  • mongodump
  • mongorestore

实战

  1. $ mongo
  2. > show dbs;
  3. > use komablog;
  4. > db.posts.find({}, {_id:0});
  5. > exit
  6. $ mkdir dbbak
  7. $ cd dbbak
  8. $ mongodump -d komablog
  9. $ ls
  10. $ mongo komablog
  11. > db.posts.find({}, {_id:0});
  12. > db.posts.remove({});
  13. > db.posts.find({}, {_id:0});
  14. > exit
  15. $ mongorestore --drop
  16. $ mongo komablog
  17. > db.posts.find({}, {_id:0});
  18. > exit
  19. $ mongodump --help

发表评论

表情:
评论列表 (有 0 条评论,47人围观)

还没有评论,来说两句吧...

相关阅读

    相关 MongoDB 基本操作

    MongoDB 基本操作 MongoDB 是一个面向文档存储的数据库 数据库 一个MongoDB 中可以创建多个数据库,每个数据库都有自己的集合和权限,不同

    相关 mongodb基本操作

    一. mongoDB简介    MongoDB安装时不添加任何参数,默认是没有权限验证的,登录的用户可以对数据库任意操作而且可以远程访问数据库,需以 --auth 参数启

    相关 MongoDB--基本操作

    创建数据库 `use 数据库名` 使用use时,如果数据库存在则会进入到相应的数 据库,如果不存在则会自动创建 一旦进入数据库,则可以使用db来