数据库-mongodb 学习笔记(全)

数据库概述及安装.avi

  • 数据库就是存储数据的仓库,可以对数据进行分类存储,并提供强大的操作数据的方法,是一个独立的软件
  • 常用的数据库有:mysql、mongodb、orcle。。。
  • mongodb是我们前端上手最快的数据库,我们先学习数据库相关的概念,日后再学习其他数据库时就会很轻松

数据库相关概念.avi

  • 数据库(database):一个数据库软件中可以创建多个数据库,每个数据库都是独立的存储数据的仓库
  • 集合(collection):集合是某个数据库中的一类数据的集合(可以理解为JS中的数组)[ {}, {}, {}, {} ]
  • 文档(document):是集合中一条具体的数据(可以理解为数组中的对象){ name: ‘zs’, age: 18 }
  • 字段(field):是文档中具体的某个属性(可以理解为数组中的对象的某个键值对)name: ‘zs’

使用nodejs连接数据库.avi

  • 启动数据库,打开命令行,执行:net start mongodb

  • 停止数据库,打开命令行,执行:net stop mongodb

  • 使第三方模块mongoose去操作mongodb数据库

  • 范例:

    const mongoose = require('mongoose');
    
    // promise形式
    mongoose.connect('mongodb://localhost/mydb')
    	.then(() => { console.log('数据库连接成功'); })
    	.catch((err) => { console.log('数据库连接失败', err); });
    
    // 异步函数形式
    async function run () {
        await mongoose.connect('mongodb://localhost/mydb');
        console.log('连接成功');
    }
    

    注意:如果你连接的数据库不存在,mongodb会在第一次插入数据的时候自动给我们创建

创建集合及向集合中插入数据.avi

  • 创建集合,分为两步:

    1. 创建集合规则

    2. 应用集合规则,创建集合

      // 创建集合规则
      const userSchema = new mongoose.Schema({
          name: {
              type: String
          },
          password: String,
          isVip: Boolean
      }, {
        versionKey: false // 不生成__v字段
      });
      // 应用集合规则创建集合,这第三个参数就是在指定数据库中集合的名字
      const User = mongoose.model('User', userSchema, 'User'); // users
      
  • 创建文档,分为两步:

    1. 创建文档实例

    2. 调用save方法插入到数据库中

      // 假设是通过http请求拿到的数据
      const reqData = {
          name: '张三',
          password: 'qwe123',
          isVip: true
      }
      // 这是第一步
      const user = new User(reqData);
      // 这是第二步
      user.save();
      

向集合中插入文档的另一种方式.avi

  • 我们还可以用集合构造函数的create方法来插入文档

  • 范例:

    // 回调函数的形式
    User.create({
        name: 'andremao',
        password: 'qwe123',
        isVip: true
    }, (err, doc) => {
    	// code...
    });
    
    // Promise的形式
    User.create({
        name: 'andremao',
        password: 'qwe123',
        isVip: true
    }).then(doc => {
        // code...
    }).catch(err => {
        // code...
    });
    

向数据库中导入数据.avi

  • 导入数据:mongoimport -d 数据库名称 -c 集合名称 --file 要导入的文件
  • 注意:mogodb安装目录的bin目录下存放的是mongodb相关的可执行文件,需要加入到path系统环境变量中

查询文档(一).avi

  • 查找多个:find(),返回的是数组
  • 查找一个:findOne(),返回的是一个文档,如果匹配到多条,返回第一条
  • 共同点:它们都返回Promise对象,都可以带查询条件

查询文档(二).avi

  • 大于、小于、大于等于、小于等于

    User.find({age: {$gt: 20, $lt: 50, $gte: 18, $gle: 100}}).then(result => console.log(result));
    
  • 包含

    User.find({hobbies: {$in: ['敲代码']}}).then(result => console.log(result));
    
  • 筛选字段

    User.find().select('name age').then(result => console.log(result));
    
  • 排序

    // 升序
    User.find().sort('age').then(result => console.log(result));
    // 降序
    User.find().sort('-age').then(result => console.log(result));
    
  • 跳过n条,查n条,可以用来做分页

    User.find().skip(3 * 10).limit(10).then(result => console.log(result));
    

删除文档.avi

  • 删除单个:

    User.findOneAndDelete({ 条件 }).then....
    
    • 返回的是被删除的文档
    • 如果匹配到多条,删除第一条
  • 删除多个:

    User.deleteMany({ 一定不要忘记带条件 }).then...
    
    • 返回值是本次删除操作的信息对象,形如:{ n: 2, ok: 1, deletedCount: 2 }

      • n:表示匹配的条数
      • ok:表示本次删除操作是否执行成功,1:成功,0:失败
      • deletedCount:代表已经被删除的条数
      • 补充说明:当本次删除操作异常时,n和deletedCount就有可能不一致

更新文档.avi

  • 更新单个

    User.updateOne({ 条件 }, { 要修改的值 }).then...
    
    • 返回值是更新信息对象,形如:{ n: 1, nModified: 1, ok: 1 }
      • n:表示匹配的条数
      • nModified:表示已经更新的条数
      • ok:表示本次更新操作是否执行成功,1:成功,0:失败
  • 更新多个

    User.updateMany({ 条件 }, { 要修改的值 }).then...
    
    • 返回值同updateOne

mongoose验证(一).avi

  • 在创建集合的时候,可以设置当前字段的验证规则,验证失败就不允许插入

    • 必选:required
    • 字符串最小长度:minlength
    • 字符串最大长度:maxlength
    • 去除字符串两边的空格:trim
  • 可以用数组的形式的第二个参数指定错误消息,如:

    name: {
        type: String,
        minlength: [2, '你的名字太短了']
    }
    

mongoose验证(二).avi

  • 最小值:min

  • 最大值:max

  • 默认值:default

  • 枚举值:enum

  • 自定义验证规则:validate

    • 范例:

      const userSchema = new mongoose.Schema({
          age: {
              type: Number,
              validate: {
                  validator: v => {
                      // 这个v就是实际的要验证的值
                      // 如果让这个验证通过,返回ture,否则返回false
                      return v > 18 && v < 100;
                  },
                  message: '你的年龄有错误'
              }
          }
      });
      

捕获mongoose错误信息.avi

.catch(err => {
    const { errors } = err; // 等价于  const errors = err.errors;
    for (let key in errors) {
        const msg = errors[key].message;
        console.log(msg);
    }
})
  • 这个errors不是数组,是一个对象

集合关联.avi

  • 使用id对集合进行关联,类型是:mongoose.Schema.Types.ObjectId

  • 使用populate方法来对集合关联查询

  • 范例

    const mongoose = require('mongoose');
    
    // 用户集合
    const User = mongoose.model('User', new mongoose.Schema({
        name: String
    }));
    
    // 文章集合
    const Artilce = mongoose.model('Article', {
        title: String,
        author: {
            type: mongoose.Schema.Types.ObjectId,
            ref: 'User'
        },
        admin: {
            type: mongoose.Schema.Types.ObjectId,
            ref: 'Admin'
        }
    });
    
    Artilce.find().populate('author admin').then...
    

60-案例:用户信息增删改查(一).avi
61-案例:用户信息增删改查(二).avi
62-案例:用户信息增删改查(三).avi
63-案例:用户信息增删改查(四).avi
64-案例:用户信息增删改查(五).avi
65-案例:用户信息增删改查(六).avi
66-案例:用户信息增删改查(七).avi

你可能感兴趣的:(数据库-mongodb 学习笔记(全))