Node.js开发-MongoDB

这篇具有很好参考价值的文章主要介绍了Node.js开发-MongoDB。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1) Mongoose

介绍

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

作用

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

使用流程

// 导入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) 插入文档

// 导入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 有一些内建验证器,可以对字段值进行验证

必填项

title: {
    type: String,
    required: true // 设置必填项
},

默认值

author: {
    type: String,
    default: '匿名' //默认值
},

枚举值

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

唯一值 (主键)

username: {
    type: String,
    unique: true
},

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

5) CRUD

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

1) 增加

插入一条

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

批量插入

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

2) 删除

删除一条数据

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

批量删除

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

3) 更新

更新一条

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

批量更新

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

4) 查询

查询单条数据

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

根据id查询

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

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

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

6) 条件控制

1) 运算符

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

  • > 使用 $gt

  • < 使用 $lt

  • >= 使用 $gte

  • <= 使用 $lte

  • !== 使用 $ne

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

2) 逻辑运算

$or 逻辑或的情况

db.students.find({$or: [{age:18},{age:24}]});

$and 逻辑与的情况

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

3) 正则匹配

条件中可以直接使用 JS 的正则语法,通过正则可以进行模糊查询文章来源地址https://www.toymoban.com/news/detail-830541.html

db.students.find({name://});
db.students.find({name: new RegExp('刘')});

7) 个性化读取

1) 字段筛选

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

2) 数据排序

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

3) 数据截取

//skip 跳过 limit 限定
SongModel.find().skip(10).limit(10).exec(function(err,data){
    if(err) throw err;
    console.log(data);
    mongoose.connection.close();
});

到了这里,关于Node.js开发-MongoDB的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Node.Js篇 NodeJs使用MongoDB

    目录 介绍 概念解析                   安装 启动时注意事项 NodeJs操作Mongo 介绍 MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。                                                           

    2024年02月09日
    浏览(51)
  • 在 Node.js 中使用 MongoDB 事务

    MongoDB事务 事务介绍 在 MongoDB 中,对单个文档的操作是原子的。由于您可以使用嵌入的文档和数组来捕获单个文档结构中的数据之间的关系,而不是跨多个文档和集合进行规范化,因此这种单一文档的原子性消除了对多文档的需求许多实际用例的事务。 对于需要对多个文档(

    2024年02月10日
    浏览(38)
  • 前端Vue Node.js + Express + MongoDB 构建的后端服务API接口

    构建一个使用 Vue.js 作为前端, Node.js + Express + MongoDB 作为后端服务的全栈应用涉及到多个步骤。这里简要概述整个过程,并提供一些基本的代码示例来帮助你开始。 安装 MongoDB: 根据你的操作系统从 MongoDB 官网 下载并安装 MongoDB。 启动 MongoDB 服务: 安装完成后,根据 MongoDB 的

    2024年04月14日
    浏览(52)
  • node中的数据持久化之mongoDB

    MongoDB 是一种 开源的非关系型数据库 ,正如它的名字所表示的, MongoDB 支持的数据结构非常松散,是一种以 bson 格式(一种 json 的存储形式)的 文档存储方式 为主,支持的数据结构类型更加丰富的 NoSQL 数据库。它是一种 介于关系数据库和非关系数据库之间的产 品,是非关

    2024年02月13日
    浏览(39)
  • 〖Python 数据库开发实战 - MongoDB篇⑧〗- MongoDB的数据结构

    订阅 Python全栈白宝书-零基础入门篇 可报销! 白嫖入口-请点击我。 推荐他人订阅,可获取扣除平台费用后的35%收益,文末名片加V! 说明:该文属于 Python全栈白宝书专栏, 免费阶段订阅数量4300+ , 购买任意白宝书体系化专栏可加入 TFS-CLUB 私域社区。 福利:加入社区的小伙

    2023年04月09日
    浏览(79)
  • node教程(四)Mongodb+mongoose

    1.1Mongodb是什么? Mongodb是一个基于分布式文件存储的数据库 1.2数据库是什么? 数据库是按照数据结构来组织、存储和管理数据的应用程序。 1.3数据库的作用 主要作用就是管理数据,对数据进行增删改查 1.4数据库管理数据的特点 相比于纯文件,数据库管理数据具有如下特点

    2024年02月05日
    浏览(45)
  • centos配置nginx+node前后台+mongodb

    centos 环境下安装

    2024年02月11日
    浏览(49)
  • 〖Python 数据库开发实战 - MongoDB篇⑯〗- MongoDB创建索引时的一些实用的重要选项参数

    订阅 Python全栈白宝书-零基础入门篇 可报销! 白嫖入口-请点击我。 推荐他人订阅,可获取扣除平台费用后的35%收益,文末名片加V! 说明:该文属于 Python全栈白宝书专栏, 免费阶段订阅数量4300+ , 购买任意白宝书体系化专栏可加入 TFS-CLUB 私域社区。 福利:加入社区的小伙

    2024年02月02日
    浏览(64)
  • 【node进阶】浅析Koa框架---ejs模板|文件上传|操作mongoDB

    ✅ 作者简介:一名普通本科大三的学生,致力于提高前端开发能力 ✨ 个人主页:前端小白在前进的主页 🔥 系列专栏 : node.js学习专栏 ⭐️ 个人社区 : 个人交流社区 🍀 学习格言: ☀️ 打不倒你的会使你更强!☀️ 💯 刷题网站:这段时间有许多的小伙伴在问有没有什么

    2024年01月25日
    浏览(47)
  • node.js之连接数据库

    我们如何在nodejs中连接并操作数据库呢? 让我为大家解答一下吧! 1.安装操作MySQL数据库的第三方块 (mysql) mysql 模块是托管于 npm 上的第三方块。它提供了在 Nodejs 项目中连接和操作 MySQL 数据库的能力想要在项目中使用它,需要先运行如下命令,将mysql安装为项目的依赖包 2

    2024年01月19日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包