MongoDB笔记

MongoDB数据库

1. 数据库概述及环境搭建

1.1 为什么使用数据库

  • 动态网站中的数据都是存储在数据库中的,用户通过不同的参数访问不同页面
  • 数据库可以用来持久化存储客户端通过表单收集的用户信息
  • 数据库软件本身可以对数据进行高效的管理

1.2 什么是数据库

数据库即存储数据的仓库,可以将数据进行有序的分门别类的存储。他是独立于语言之外的软件,可以通过API去操作它。

常见的数据库软件有:mysql、mongoDB、oracle。

在这里插入图片描述

1.3 MongDB数据库下载安装

下载地址:https://www.mongodb.com/download-center/community

在这里插入图片描述

1.4 MongoDB可视化软件

MongoDB compass 可视化操作软件,是使用图形界面操作数据库的一种方式。

在这里插入图片描述

1.5 数据库相关概念

在一个数据库软件中可以包含多个数据仓库,在每个数据仓库中可以包含多个数据集合,每个数据集合中可以包含多条文档(具体的数据)。

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

2. 数据库连接

2.1 MongoDB 第三方包

使用Node.js操作MongoDB数据库需要依赖Node.js第三方包mongoose

使用 npm install mongoose 命令下载

2.2 启动MongoDB

在命令行工具中运行 net start mongoDB即可以启动MongoDB,否则MongoDB将无法连接。

net stop mongoDB 停止MongoDB

2.3 数据库连接

使用 mongoose 提供的 connect 方法即可连接 数据库。

// 引入mongoose第三方模块 用来操作数据库
const mongoose = require('mongoose');
// 数据库连接  数据库地址/数据库名称,若没有这个数据库,自动创建这个数据库
mongoose.connect('mongodb://localhost/playground', { useNewUrlParser: true})
	// 通过调用 .then .catch 来看数据库是否连接成功
	// 连接成功
	.then(() => console.log('数据库连接成功'))
	// 连接失败
	.catch(err => console.log(err, '数据库连接失败'));

在这里插入图片描述

连接数据库成功时,终端的提示代表:当前的URL废弃了,在将来的版本会删除掉,使用新的解析器;在connect第二个参数加上 { useUnifiedTopology: true }这个配置即可;

2.4 创建数据库

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

3. MongdoDB增删改查操作

3.1 创建集合

创建集合分为两步,一是对集合设定规则,二是创建集合,创建mongoose.Schema构造函数的实例即可创建集合。

// 创建集合规则
const courseSchema = new mongoose.Schema({
	name: String,
	author: String,
	isPublished: Boolean
});

// 使用规则创建集合
// 第一个参数为集合名称首字母大写(在数据库其实创建的为courses),第二个参数为创建的集合规则
const Course = mongoose.model('Course', courseSchema) // courses

创建了集合规则,是没有数据库的,需要向集合规则中插入数据才会显示数据库

3.2 向集合中插入数据

创建集合实例的第一种方法:

分为两步:

  1. 创建集合实例。
  2. 调用实例对象下的save方法将数据保存到数据库中。
// 创建集合实例
const course = new Course({
    // 创建的实例化要与集合规则相对应
	name: 'node.js基础',
	author: '黑马讲师',
	isPublished: true
});
// 将文档插入到数据库中
course.save();
创建集合实例的第二种方法:
// 回调函数的方式
Course.create({name: 'JavaScript基础', author: '黑马讲师', isPublish: true}, (err, doc) => { 
     //  错误对象
    console.log(err)
     //  当前插入的文档
    console.log(doc)
});

// promise 以上代码也可以调用 .then 方法
Course.create({name: 'JavaScript基础', author: '黑马讲师', isPublish: true})
      .then(doc => console.log(doc))
      .catch(err => console.log(err))

3.3 mongoDB数据库导入数据

mongoimport -d 数据库名称 -c 集合名称 --file 要导入的数据文件,导入成功后如下

在这里插入图片描述

若报一下错误,找到mongodb数据库的安装目录,将安装目录下的bin目录放置在环境变量中

在这里插入图片描述

在这里插入图片描述

3.4 查询文档

//  根据条件查找文档(条件为空则查找所有文档)
Course.find().then(result => console.log(result))
// 返回文档集合
[{
    hobbies: [ '足球', '篮球', '橄榄球' ],
    _id: 5c09f1e5aeb04b22f8460965,
    name: '张三',
    age: 20,
    email: 'zhangsan@itcast.cn',
    password: '123456'
  },
  {
    hobbies: [ '敲代码' ],
    _id: 5c09f267aeb04b22f8460968,
    name: '王五',
    age: 25,
    email: 'wangwu@itcast.cn',
    password: '123456'
	},
	...
]
//  根据条件查找文档
Course.findOne({name: '张三'}).then(result => console.log(result))
// 返回文档
 {
    hobbies: [ '足球', '篮球', '橄榄球' ],
    _id: 5c09f1e5aeb04b22f8460965,
    name: '张三',
    age: 20,
    email: 'zhangsan@itcast.cn',
    password: '123456'
}
 //  匹配大于 小于  $gt 表示大于  $lt: 表示小于
 User.find({age: {$gt: 20, $lt: 50}}).then(result => console.log(result))
 //  匹配包含
 User.find({hobbies: {$in: ['敲代码']}}).then(result => console.log(result))
 //  选择要查询的字段 如:name email   不想查询的字段前面加 - 如:-_id 
 User.find().select('name email -_id').then(result => console.log(result))
 // 将数据按照age进行排序,若想降序 在age前面加 -,如: -age
 User.find().sort('age').then(result => console.log(result))
 //  skip 跳过多少条数据  limit 限制查询数量
 User.find().skip(2).limit(2).then(result => console.log(result))

3.5 删除文档

 // 删除单个 查询一条数据并删除 如果查找多条则删除第一条
Course.findOneAndDelete({}).then(result => console.log(result))
 // 删除多个 {} 删除所有
User.deleteMany({}).then(result => console.log(result)

3.6 更新文档

// 更新单个
User.updateOne({查询条件}, {要修改的值}).then(result => console.log(result))
// 更新多个
User.updateMany({查询条件}, {要更改的值}).then(result => console.log(result))

3.6 mongoDB验证

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

// 验证规则
const userSchema =  mongoose.Schema({
    title: {
        type: String,
        // 必选字段
        required: [true, '请传入文章标题'],
        // 字符串最小长度
        maxlength: [2, '文章长度最小不能小于2'],
        // 字符串最大长度
        minlength: [10, '文章长度最大不能大于10'],
        // 去除字符串两端空格
        trim: true
    },
    category:{
        type: String,
        // m枚举 列举出当前字段可以拥有的值
        enum: {
            values: ['html', 'css', 'javascript', 'node.js'],
            message: '分类名称要在规定的范围之内'
        }
    },
    author: {
        type: String,
        validata: {
            validata: v => {
                // 返回布尔值 true 验证通过  false 验证失败  v 要验证的值
                return v && v.length > 4
            },
            // 自定义错误信息
            message: '传入的值不符合验证规则'
        }
    }
});

获取错误信息

Post.create({title: 'aa', age: 60, category: 'java', author: 'bd'})
    .catch(error => {
        // 获取错误信息
        const err = error.errors;
        // 循环错误信息对象
        for(var attr in err) {
            // 将错误打印到控制台中
            console.log(err[attr]['message']);
        }
    })
  • required: true 必传字段
  • minlength:3 字符串最小长度
  • maxlength: 20 字符串最大长度
  • min: 2 数值最小为2
  • max: 100 数值最大为100
  • enum: [‘html’, ‘css’, ‘javascript’, ‘node.js’]
  • trim: true 去除字符串两边的空格
  • validate: 自定义验证器
  • default: 默认值

获取错误信息:error.errors[‘字段名称’].message

3.7 集合关联

通常不同集合的数据之间是有关系的,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的,要查询文章的所有信息包括发表用户,就需要用到集合关联。

  • 使用id对集合进行关联
  • 使用populate方法进行关联集合查询
集合关联实现
// 用户集合
const User = mongoose.model('User', new mongoose.Schema({ name: { type: String } })); 
// 文章集合
const Post = mongoose.model('Post', new mongoose.Schema({
    title: { type: String },
    // 使用ID将文章集合和作者集合进行关联
    author: { 
        type: mongoose.Schema.Types.ObjectId, 
        // 集合名称
        ref: 'User' 
    }
}));
//联合查询
Post.find()
      .populate('author')
      .then((err, result) => console.log(result));
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值