MongoDB

MongoDB数据库的基本概念

- 可以有多个数据库
- 一个数据库中可以有多个集合(相当于SQL中的表)【数组】
- 一个集合中可以有多个文档(表记录)
- 文档结构很灵活,没有任何限制

MongoDB的存储结构

// 大括号就是MongoDB
{
    // 里面有很多不同的数据库,每个数据库也是一个对象
    qq: {
        // qq数据库里面有很多的集合(表),users数据集合就是数组
        users: [
            {name: '张三', age:25},
            {name: '张三', age:25},
            {name: '张三', age:25},
            {name: '张三', age:25},
            {name: '张三', age:25},
            ...
        ],
        products: [

        ],
        ...
    },
    taobao: {

    },
    baidu: {

    }
}

启动和关闭数据库

启动:

# mongodb 默认使用 执行 mongod 命令所处盘符根目录下的 /data/db 作为自己的数据存储目录
# 所以在第一次执行该命令之前先自己手动新建一个 /data/db 文件夹
mongod #启动mongodb服务

如果想要修改默认的数据存储目录,可以:

mogod --dvpath=数据存储目录路径

停止:

关闭开启服务的控制台

连接数据库

# 该命令默认连接本机的 MongoDB 服务
mongo

退出:

#在连接状态输入 exit 退出连接
exit

基本命令

  • show dbs
    • 查看显示所有数据库
  • db
    • 查看当前操作的数据库
  • use 数据库名称
    • 切换到指定的数据库(如果没有会新建)
  • 插入数据(是插入一个对象,没有任何限制,非常灵活)
    • db.students.insertOne({"name": "jack"})
    • db.students.insertOne({"name": "jack","age": 18})
  • 查询表(NoSQL里没有表的概念。表就是集合collection)
    • show collections
  • 查询数据
    • db.students.find()

在Node中如何操作MongoDB数据库

使用 mongoose 来操作mongoDB数据库

第三方包: mongoose 基于MongoDB官方的mongodb包再一次做了封装
网址:(mongoosejs.com)

mongoose HelloWorld

const mongoose = require('mongoose');

// 连接 MongoDB 数据库 
mongoose.connect('mongodb://localhost:27017/test', {useNewUrlParser: true});

// 创建一个模型,就是在设计数据库
// MongoDB 是动态的,非常灵活,只需要在代码中设计你的数据库就可以了。
// mongoose 这个包就可以让你的设计编写过程变得非常简单
const Cat = mongoose.model('Cat', { name: String }); //第一个参数是表名,也就是集合名称,会自动生成一个小写的cats集合,第二个参数就是数据结构

// 实例化一个 Cat
const kitty = new Cat({ name: 'Zildjian' });

// 持久化保存 kitty实例
kitty.save().then(() => console.log('meow'));
  • 连接数据库

var mongoose = require('mongoose')
1. 连接数据库,指定连接的数据库不需要存在,当你插入第一条数据之后就会被自动创建出来
mongoose.connect('mongodb://localhost/test') 
  • Defining your schema

    • Everything in Mongoose starts with a Schema. Each schema maps to a MongoDB collection and defines the shape of the documents within that collection.
    • Schema里面可以加约束
  var mongoose = require('mongoose');
  var Schema = mongoose.Schema;

  var blogSchema = new Schema({
    title:  {
        type: String,
        required: true
    }, 
    author: String,// String is shorthand for {type: String}
    body:   String,
    comments: [{ body: String, date: Date }],
    date: { type: Date, default: Date.now },
    hidden: Boolean,
    meta: {
      votes: Number,
      favs:  Number
    }
  });
  • Creating a model

To use our schema definition, we need to convert our blogSchema into a Model we can work with.

第一个参数:
- 传入一个大写名词单数字符串用来表示你的数据库名称
- mongoose 会自动将大写名词单数的字符串 解析成 小写复数 形式的集合名称作为最终数据库里面的集合名
- 例如这里的 User 最终会变成 users 集合名称
第二个参数:架构Schema

返回值: 模型构造函数

 var Blog = mongoose.model('Blog', blogSchema);
  • Constructing Documents

An instance of a model is called a document. Creating them and saving to the database is easy.

增删改查

增加一条数据

var mongoose = require('mongoose')

// 1. 连接数据库,指定连接的数据库不需要存在,当你插入第一条数据之后就会被自动创建出来
mongoose.connect('mongodb://localhost/itcast')

 var Schema = mongoose.Schema;

// 2. 设计文档结构(表结构),包括约束
// 约束的目的是为了保证数据的完整性,不要有脏数据

var userSchema = new Schema({
    username: { // 后面加个对象就代表对username这个字段添加约束
        type: String,
        required: true
    },
    password: {
        type: String,
        required: true
    },
    email: {
        type: String
    }
})

// 3. 将文档结构发布为模型
var User = mongoose.model('User', userSchema)


// 新增一条数据,通过new({对象})
var admin = new User({
    username: 'admin',
    password: '12345678',
    email: 'why1234me@163.com'
})

// 持久化保存
admin.save(function (err, ret) {
    if (err) {
        console.log('存储失败')
    } else {
        console.log('保存成功')
        console.log(ret)
    }
})

查询数据

Model 的方法中包含查询条件参数的( find findById count update )都可以按以下两种方式执行:

  • 传入 callback 参数,操作会被立即执行,查询结果被传给回调函数( callback )。

  • 模型.find({查询条件1,查询条件2}, '查询字段1 查询字段2', 回调函数)

find方法查出来的是满足的文档数组,findOne方法查出来的是满足查询的第一个文档。

User.find({ username: 'admin', password: '12345678'},  'username password', function (err, docs) {
        if (err) {
            console.log("查询失败")
        } else {
            console.log(docs)
        }
    } )

find查询结果:是个数组

[
  {
    _id: 5def5e6386ca9ac838313c0b,
    username: 'admin',
    password: '12345678'
  }
]
  • 不传 callback 参数,Query 的一个实例(一个 query 对象)被返回,这个 query 提供了构建查询器的特殊接口。
    • 查询条件
      • var query = User.findOne({ 'username': 'admin' })
    • 查询字段(用query对象来查询)
      • query.select('username email')
    • 执行查询
      • query.exec(function (err, doc) { });

findOne查询结果:是个对象

{
  _id: 5def5e6386ca9ac838313c0b,
  username: 'admin',
  email: 'why1234me@163.com'
}

删除:

  • Model.remove():

DeprecationWarning: collection.remove is deprecated. Use deleteOne, deleteMany, or bulkWrite instead.
Removes all documents that match conditions from the collection. To remove just the first document that matches conditions, set the single option to true.

示例:

User.remove({ username: 'user3' }, function (err) {});
  • Model.deleteOne():

Deletes the first document that matches conditions from the collection. Behaves like remove(), but deletes at most one document regardless of the single option.

示例:

User.deleteOne({ username: 'user2' }, function (err) { }
  • Model.deleteMany():

Deletes all of the documents that match conditions from the collection. Behaves like remove(), but deletes all documents that match conditions regardless of the single option.

示例:

User.deleteMany({ username: 'user2' }, function (err) { }

更新

  • Model.findByIdAndUpdate(id, update, callback):根据Id更新一个
    示例:
User.findByIdAndUpdate('5def6d64857c1cc8644e3778', {password: '123'}, function (err, ret) { })
  • Model.findOneAndUpdate(conditions, update, callback)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容

  • 配置 修改config/database.php在connection数组中添加mongodb的配置信息,如下 '...
    jooohnny阅读 8,422评论 3 8
  • 参考资料https://www.npmjs.com/package/mongodbhttps://docs.mon...
    程序员有话说阅读 754评论 0 4
  • 曾自己借助阿里云和hexo搭了个站点,现已废弃,过往写的博客暂挪到此处。 title: MongoDB 初接触da...
    monvhh阅读 440评论 0 0
  • Mongodb 配置选项 通常在mongod.conf中 配置文件 设置了配置文件后启动时以自定义的配置文件启动:...
    AkaTBS阅读 1,079评论 0 6
  • MongoDB 1. MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用...
    Kevinr阅读 1,560评论 0 3