MongoDB笔记

MongoDB的安装

知识点

  • MongoDB安装文件下载(Windows/Mac)
  • Ubuntu Server 16.04 LTS安装(apt)
  • mongod服务启动

MongoDB安装文件下载

https://www.mongodb.com/download-center

Ubuntu安装

https://docs.mongodb.com/master/tutorial/install-mongodb-on-ubuntu/

$ sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5
$ echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.6 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.6.list
$ sudo apt-get update
$ sudo apt-get install -y mongodb-org
$ sudo service mongod start
$ sudo service mongod restart
$ sudo service mongod stop

mongod服务启动

$ cd /lib/systemd/system
$ cat mongod.service
$ sudo systemctl start mongod.service
$ sudo systemctl stop mongod.service
$ sudo systemctl enable mongod.service
$ sudo systemctl is-enabled mongod.service

基本概念的理解

知识点

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

关系型数据库

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

数据库使用步骤

  1. 建立数据库(KomaBlog)
  2. 建立数据集合(Posts, Categories, Tags)
  3. 建立数据(Post:{"_id":"",“title”:""})
  • KomaBlog
    • Posts
      • {"_id":“1”,“title”:“我的第一篇博客”}
      • {"_id":“2”,“title”:“我的第二篇博客”}
      • {"_id":“3”,“title”:“我的第三篇博客”,“delflg”:1}
    • Categories
      • {"_id":“1”,“title”:“游戏”}
      • {"_id":“2”,“title”:“技术”}
    • Tags
      • {"_id":“1”,“title”:“光荣系列”}
      • {"_id":“2”,“title”:“任天堂系列”}
      • {"_id":“3”,“title”:“Ubuntu”}

NoSql

在NoSql的数据库中,操作数据都是通过指令或程序语言完成的,比如在MongoDB中使用过Javascript和JSON数据结构,来操作和管理数据的。

简简单单NoSql

知识点

  • mongo命令行工具
  • 建立删除数据库

实战演习

$ mongo
> help
> exit
$ mongo
> show dbs;
> use komablog;
> show collections;
> db.createCollection("posts");
> db.createCollection("categories");
> db.createCollection("tags");
> show collections;
> show dbs;
> db.stats();
> db.dropDatabase();
> show dbs;

操作集合(Collection)

知识点

  • MongoDB数据集合的操作

实战演习

$ mongo
> show dbs;
> use komablog;
> show collections;
> db.createCollection("users");
> show collections;
> db.users.renameCollection("staff"); // users -> staff
> show collections;
> db.staff.drop();
> show collections;
> db.dropDatabase();
> show dbs;

操作文档(Document)

知识点

  • MongoDB数据文档的操作

实战演习

$ mongo
> use komablog;
> show collections;
> db.createCollection("posts");
> db.posts.insert(
... {
...     title: "我的第一篇博客",
...     content: "已经开始写博客了,太激动了。"
... }
... );
> show collections;
> db.posts.find();
> 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();
> db.posts.remove({});
> db.posts.count();
> db.posts.find();

带条件的文档

知识点

  • 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"});
> db.posts.find({"rank": {$gte: 4}});
> db.posts.find({"rank": {$gt: 4}});
> db.posts.find({"rank": {$lte: 4}});
> db.posts.find({"rank": {$lt: 4}});
> db.posts.find({"title": /u/});
> db.posts.find({"title": /^R/});
> db.posts.find({"title": /^U/});
> db.posts.distinct("tag");

复杂条件抽文档

知识点

  • db.[collection_name].find({"":"", “”:""})
  • db.[collection_name].find({$or:[{…},{…}]});
  • db.[collection_name].find({"": {$in: […]}});
  • db.[collection_name].find({"": {$exists: true}});

实战演习

$ mongo
> use komablog;
> db.posts.find();
> db.posts.find({"title": /u/, "rank":{$gte:5} });
> db.posts.find({$or: [{"title": /u/}, {"rank":{$gte:4}}] });
> db.posts.find({"rank": {$in: [3,4]} });
> db.posts.insert({ "title":"惊!骑士发生重大交易", "istop": true });
> db.posts.find({"istop": {$exists: true} });

指定抽出字段

知识点

  • db.[collection_name].find({}, {field1: true, field2: 1})

实战演习

$ mongo
> use komablog;
> db.posts.find();
> db.posts.find({}, {title:true, rank:1});
> db.posts.find({}, {title:true, rank:1, _id:0});

文档的方法

知识点

  • sort()
  • limit()
  • skip()

实战演习

$ mongo
> use komablog;
> db.posts.find();
> db.posts.find({}, {_id:0}).sort({rank:1});
> db.posts.find({}, {_id:0}).sort({rank:-1});
> db.posts.find({}, {_id:0}).limit(3);
> db.posts.find({}, {_id:0}).sort({rank:-1}).limit(3);
> db.posts.findOne({}, {_id:0});
> db.posts.find({}, {_id:0});
> db.posts.find({}, {_id:0}).limit(3);
> db.posts.find({}, {_id:0}).skip(3).limit(3);

文档更新(update)

知识点

  • update(, , )

命令参考网页

https://docs.mongodb.com/manual/reference/method/db.collection.update

实战演习

$ mongo
> use komablog;
> db.posts.findOne({"title":"怪物猎人世界评测"});
> db.posts.update({"title":"怪物猎人世界评测"}, {$set: {"rank": 10} });
> db.posts.find();
> db.posts.update({"title":"怪物猎人世界评测"}, {"rank": 99});
> db.posts.find();
> db.posts.update({"tag":"it"}, {$set: {"rank": 50}});
> db.posts.find();
> db.posts.update({"tag":"it"}, {$set: {"rank": 60}}, {multi: true});
> 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}});
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$mul: {rank: 2}});
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$rename: {"rank": "score"}});
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$set: {"istop": true}});
> db.posts.find({title:"怪物猎人世界评测"}, {_id:0});
> db.posts.update({title:"怪物猎人世界评测"}, {$unset: {"istop": true}});
> 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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值