Node.js开发-MongoDB

MongoDB

1) Mongoose

介绍

Mongoose 是一个对象文档模型库,官网 http://www.mongoosejs.net/

作用

方便使用代码操作 mongodb 数据库

使用流程

js 复制代码
// 导入mongoose
const mongoose = require("mongoose");

// 连接 mongodb
mongoose.connect('mongodb://127.0.0.1:27017/bilibili');

// 设置回调
mongoose.connection.on("open", () => {
    // 设置连接成功的回调
    console.log("连接成功");
});
mongoose.connection.on("error", () => {
    // 设置连接错误的回调
    console.log("连接失败");
});
mongoose.connection.on("close", () => {
    // 设置连接关闭的回调
    console.log("连接关闭");
});

// 关闭连接
setTimeout(() => {
    mongoose.disconnect();
}, 2000);

2) 插入文档

js 复制代码
// 导入mongoose
const mongoose = require("mongoose");

mongoose.set('strictQuery', false);

// 连接 mongodb
mongoose.connect('mongodb://127.0.0.1:27017/bilibili');

// 设置回调
mongoose.connection.once("open", () => {
    // 创建文档的结构对象
    let BookSchema = new mongoose.Schema({
        name: String,
        author: String,
        price: Number
    });

    // 创建模型对象
    let BookModel = mongoose.model('books', BookSchema);

    // 新增
    BookModel.create({
        name: "西游记",
        author: "吴承恩",
        price: 19.9
    }, (err,data)=>{
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
        
        mongoose.disconnect();
    });
});
mongoose.connection.on("error", () => {
    // 设置连接错误的回调
    console.log("连接失败");
});
mongoose.connection.on("close", () => {
    // 设置连接关闭的回调
    console.log("连接关闭");
});

3) 字段类型

文档结构可选的常用字段类型列表

类型 描述
String 字符串
Number 数字
Boolean 布尔值
Array 数组,也可以使用[]来标识
Date 日期
Buffer Buffer 对象
Mixed 任意类型,需要使用 mongoose.Schema.Types.Mixed 指定
ObjectId 对象 ID,需要使用 mongoose.Schema.Types.ObjectId 指定
Decimal128 高精度数字,需要使用 mongoose.Schema.Types.Decimal128 指定

4) 字段值验证

Mongoose 有一些内建验证器,可以对字段值进行验证

必填项

js 复制代码
title: {
    type: String,
    required: true // 设置必填项
},

默认值

js 复制代码
author: {
    type: String,
    default: '匿名' //默认值
},

枚举值

js 复制代码
gender: {
    type: String,
    enum: ['男','女'] //设置的值必须是数组中的
},

唯一值 (主键)

js 复制代码
username: {
    type: String,
    unique: true
},

unique 需要 重建集合 才能有效果

5) CRUD

数据库的基本操作包括四个,增加(create),删除(delete),修改(update),查(read)

1) 增加

插入一条

js 复制代码
SongModel.create({
    title:'给我一首歌的时间',
    author: 'Jay'
}, function(err, data){
    //错误
    console.log(err);
    //插入后的数据对象
    console.log(data);
});

批量插入

js 复制代码
PhoneModel.insertMany([
    {
        brand:'华为',
        color:'灰色',
        price:2399,
        tags:['电量大','屏幕大','信号好']
    },
    {
        brand:'小米',
        color:'白色',
        price:2099,
        tags:['电量大','屏幕大','信号好']
    }],(err,data)=>{
        if(err) throw err;
        console.log('写入成功');
        mongoose.connection.close();
})

2) 删除

删除一条数据

js 复制代码
BookModel.deleteOne({_id: "65c60c85df92ad81ab74d4a8"}, (err, data) => {
    // 判断
    if (err) {
        console.log("删除失败~~");
        return;
    }
    console.log(data);
});

批量删除

js 复制代码
BookModel.deleteMany({is_hot: false}, (err, data) => {
    if (err) {
        console.log("删除失败~~");
        return;
    }
    console.log(data);
});

3) 更新

更新一条

js 复制代码
BookModel.updateOne({name: "红楼梦"}, {price: 9.9}, (err, data) => {
    if (err) {
        console.log(err);
        return;
    }
    console.log(data);
});

批量更新

js 复制代码
BookModel.updateMany({author: "余华"}, {is_hot: false}, (err, data) => {
    if (err) {
        console.log(err);
        return;
    }
    console.log(data);
});

4) 查询

查询单条数据

js 复制代码
BookModel.findOne({name: "狂飙"}, (err, data) => {
    if (err) {
        console.log(err);
    }
    console.log(data);
});

根据id查询

js 复制代码
BookModel.findById({_id: "65c60c85df92ad81ab74d4b9"}, (err, data) => {
    if (err) {
        console.log(err);
    }
    console.log(data);
});

批量查询 (条件可以不添加则自动获取所有)

js 复制代码
BookModel.find({author: "余华"}, (err, data) => {
    if (err) {
        console.log(err);
    }
    console.log(data);
});

6) 条件控制

1) 运算符

在 mongodb 不能 > < >= <= !== 等运算符,需要使用替代符号

  • > 使用 $gt

  • < 使用 $lt

  • >= 使用 $gte

  • <= 使用 $lte

  • !== 使用 $ne

js 复制代码
db.students.find({id: {$gt: 3}}); id号比3大的所有的记录

2) 逻辑运算

$or 逻辑或的情况

js 复制代码
db.students.find({$or: [{age:18},{age:24}]});

$and 逻辑与的情况

js 复制代码
db.students.find({$and: [{age: {$lt:20}}, {age: {$gt: 15}}]});

3) 正则匹配

条件中可以直接使用 JS 的正则语法,通过正则可以进行模糊查询

js 复制代码
db.students.find({name:/刘/});
js 复制代码
db.students.find({name: new RegExp('刘')});

7) 个性化读取

1) 字段筛选

js 复制代码
//0:不要的字段
//1:要的字段
SongModel.find().select({_id:0,title:1}).exec(function(err,data){
    if(err) throw err;
    console.log(data);
    mongoose.connection.close();
});

2) 数据排序

js 复制代码
//sort 排序
//1:升序
//-1:倒序
SongModel.find().sort({hot:1}).exec(function(err,data){
    if(err) throw err;
    console.log(data);
    mongoose.connection.close();
});

3) 数据截取

js 复制代码
//skip 跳过 limit 限定
SongModel.find().skip(10).limit(10).exec(function(err,data){
    if(err) throw err;
    console.log(data);
    mongoose.connection.close();
});
相关推荐
jiugie8 分钟前
MongoDB学习
数据库·python·mongodb
hzulwy11 分钟前
MongoDB应用设计调优
数据库·mongodb
我爱松子鱼30 分钟前
MySQL 单表访问方法详解
数据库·mysql
我们的五年44 分钟前
MySQL存储引擎:选择与应用
数据库·mysql
带娃的IT创业者1 小时前
《Python实战进阶》专栏 No.3:Django 项目结构解析与入门DEMO
数据库·python·django
人间打气筒(Ada)2 小时前
MySQL优化
数据库·mysql
小蒜学长2 小时前
医疗报销系统的设计与实现(代码+数据库+LW)
数据库·spring boot·学习·oracle·课程设计
终端行者2 小时前
kubernetes1.28部署mysql5.7主从同步,使用Nfs制作持久卷存储,适用于centos7/9操作系统,
数据库·容器·kubernetes
羊小猪~~2 小时前
MYSQL学习笔记(九):MYSQL表的“增删改查”
数据库·笔记·后端·sql·学习·mysql·考研
我们的五年2 小时前
MySQL 架构
数据库·mysql·开源