前端上手最快的数据库MongoDB

概述及安装

  • MongoDB是我们前端上手最快的数据库,MongoDB作为其数据库,具有高性能,易使用,存储数据方便等特点,完全使用JavaScript语法即可操作。下载
  • 在安装MongoDB之前,需要先下载Node.js,到时候要基于Node对数据库进行操作
  • 使用Node.js操作MongoDB数据库需要依赖Node.js第三方包mongoose,使用npm install mongoose命令下载

MongoDB可视化软件

  • MongoDB可视化操作软件,使用图形界面操作数据库的一种方式。下载
  • 也可以使用Navicat Premium,新版也支持MongoDB,百度直接搜索也有激活教程

MongoDB概念

术语概念解释
database数据库mongoDB数据库软件中可以建立多个数据库
collection集合一组数据的集合,可以理解为JavaScript中的数组
document文档一条具体的数据,可以理解为JavaScript中的对象
field字段文档中的属性名称,可以理解为JavaScript中的对象属性

数据库操作

开启MongoDB服务

  • 在命令行工具中运行net start mongodb即可开启MongoDB服务
  • net stop mongodb停止

数据库添加账号

  1. 以系统管理员的方式运行powershell
  2. 连接数据库 mongo
  3. 查看数据库 show dbs
  4. 切换到admin数据库 use admin
  5. 创建超级管理员账户 db.createUser({ user: 'root', pwd: 'root', roles: ['root'] })
  6. 切换到blog数据 use blog
  7. 创建普通账号 db.createUser( { user: 'username', pwd: 'password', roles: ['readWrite'] } )

创建数据库

在MongoDB中不需要显式创建数据库,如果正在使用的数据库不存在,MongoDB会自动创建

向数据库导入数据

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

连接数据库

// 引用mongoose包
const mongoose = require('mongoose');
// 数据库链接
mongoose.connect('mongodb://localhost/demoDB')
	.then(() => console.log('数据库连接成功'))
	.catch(err => console.log('数据库连接失败', err));

创建集合

创建集合实际上就是对集合设定规则。

// 设置集合规则
const ArticleSchema = new mongoose.Schema({
    title: String,
    author: String,
    tags: [ String ],
    date: { type: Date, default: Date.now },
    isPublished: Boolean
});
// 使用规则创建集合 返回集合类(集合构造函数)
// 这里mongoose.model()的第三个参数是在数据库中创建时的集合名称
// 默认的是首字母小写,末尾加s (articles)
const Article = mongoose.model('Article', courseSchema, 'Articles');

创建文档

创建文档实际上就是向集合中插入具体的数据。

// 创建集合类的实例
const article = new Article ({
    title: 'Title',
    author: 'zs',
    tags: ['node', 'js'],
    isPublished: true
});
// 调用save方法将数据插入到数据库中
article.save();

插入数据的另一种形式

Article.create({title: 'Title1', author: 'ls', isPublished: true}, (err, result) => { 
     //  错误对象
    console.log(err)
     //  当前插入的文档
    console.log(result)
});
// create还支持promise 可以写成下面的形式
Article.create({title: 'Title1', author: 'ls', isPublished: true})
      .then(result => console.log(result))
      .catch(err => console.log(err))

文档操作

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

// 大于小于 (大于等于 $gte , 小于等于 $lte)
User.find({age: {$gt: 20, $lt: 50}}).then(...)

// 包含
User.find({hobbies: {$in: ['敲代码']}}).then(...)

// 筛选
User.find().select('name age').then(...)

// 升序
User.find().sort('age').then(...)
// 降序
User.find().sort('-age').then(...)

// 跳过n条,查n条,可以用来做分页
User.find().skip(3 * 10).limit(10).then(...)
删除文档
  • 删除单个:

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

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

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

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

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

Mongoose验证

在创建集合规则时,可以设置当前字段的验证规则,验证失败就则输入插入失败。

常见的验证规则:

  • required(Boolean): 必传字段
  • minlength: 字符串最小长度
  • maxlength: 字符串最大长度
  • min: 数值最小
  • max: 数值最大为
  • enum: 枚举
  • trim(Boolean):去除字符串两边的空格
  • default: 默认值
  • validate: 自定义验证器
      const userSchema = new mongoose.Schema({
          age: {
              type: Number,
              validate: {
                  validator: v => {
                      // 这个v就是实际的要验证的值
                      // 如果让这个验证通过,返回ture,否则返回false
                      return v > 18 && v < 100;
                  },
                  // 错误信息
                  message: '你的年龄有错误'
              }
          }
      });
    

可以用数组的形式的第二个参数指定错误消息,如:

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

Mongoose错误信息捕获

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

集合关联

  • 使用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...
    
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值