首页 > 数据库 >Mongodb 以及 node.js中使用mongoose操作数据库

Mongodb 以及 node.js中使用mongoose操作数据库

时间:2023-05-15 14:25:27浏览次数:45  
标签:node console log err Mongodb 文档 mongoose data

Mongodb 以及 node.js中使用mongoose操作数据库

1、lowdb

一个简陋的数据库第三方库,使用JSON文件来保存数据,进行增删改查。

在没有数据库或者数据量小到不使用数据库的时候可以使用,了解即可。

2、Mongodb是什么?

MongoDB是一个基于分布式文件存储的数据库。

相比于纯文件管理数据,数据库管理数据有如下的特点:

  • 速度更快
  • 扩展性更强
  • 安全性更强

为什么选择Mongodb,因为它的操作语法与JS类似,容易上手,学习成本低。

3、Mongodb核心概念

  • 数据库(database)数据库就是一个数据仓库,数据库服务下可以创建很多数据库,数据库中可以存放很多集合。
  • 集合(collecttion)集合类似于JS中的数组,在集合中可以存放很多文档。
  • 文档(document)文档是数据库中的最小单位,类似JS中的对象。

4、Mongodb的下载与使用

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

建议选择zip类型,通用性更强。

配置步骤如下:

  • 将压缩包移动到C:\Program Files下,然后解压
  • 创建C:\data\db目录,mongodb会将数据存在这里
  • 以mongodb中的bin目录作为工作目录,启动命令行。
  • 运行mongod.exe

看到waiting for connections就表明服务启动成功。

客户端程序

  • 运行mongo.exe

注意:

  • 为了后续方便使用mongod命令,可以将bin目录配置到环境变量path中
  • 千万不要选中服务端窗口的内容,选中会停止服务,可以敲回车取消选中

5、数据库与集合命令

5.1、数据库命令

  • 1、显示所有数据库
    • show dbs
  • 2、切换到指定数据库
    • use 数据库名
  • 3、显示当前所在的数据库
    • db
  • 4、删除当前数据库
    • use 库名
    • db.dropDatabase()

5.2、集合命令

  • 1、创建集合
    • db.createCollection('集合名称')
  • 2、显示当前数据库中的所有集合
    • show collections
  • 3、删除某个集合
    • db.集合名.drop()
  • 4、重命名集合
    • db.集合名.renameCollection('newName')

5.3、文档命令

  • 1、插入文档
    • db.集合名.insert(文档对象)
  • 2、查询文档
    • db.集合名.find({age: 20}) // 找年龄是20的文档,find不传参数,查询全部文档
  • 3、更新文档
    • db.集合名.update(查询条件,新的文档) // 不用$set,会替换掉整个文档
    • db.集合名.update({name: '张三'}, {$set:{age:19}}) // 如果用$set,只修改age
  • 4、删除文档
    • db.集合名.remove(查询条件)

6、Mongoose

Mongoose是一个对象文档模型库。

方便我们使用代码去操作mongodb数据库。

npm i mongoose@6

// 导入mongoose
const mongoose = require('mongoose');

// 连接mongoose服务
mongoose.connect('mongodb://127.0.0.1:27017/bilibili'); // 如果bilibili数据库不存在会自动创建

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

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

6.1、插入文档

// 导入mongoose
const mongoose = require('mongoose');

// 连接mongoose服务
mongoose.connect('mongodb://127.0.0.1:27017/bilibili'); // 如果bilibili数据库不存在会自动创建

// 设置回调
mongoose.connection.on('open', () => {
    // 创建文档的结构对象,设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name: String,
        author: String,
        price: Number
    });

    // 创建模型对象,对文档操作的封装对象
    let BookModel = mongoose.model('book', BookSchema);

    // 新增
    // BookModel.create({
    //     name: '西游记',
    //     author: '吴承恩',
    //     price: 19.9
    // }, (err,data) => {
    //     if (err) {
    //         console.log(err);
    //         return;
    //     }
    //     // 如果没出错,则输出插入后的文档对象
    //     console.log(data);
    // });

    // 新增多条
    BookModel.insertMany([{
        name: '西游记',
        author: '吴承恩',
        price: 19.9
    },{
        name: '西游记',
        author: '吴承恩',
        price: 19.9
    },{
        name: '西游记',
        author: '吴承恩',
        price: 19.9
    }], (err,data) => {
        if (err) {
            console.log(err);
            return;
        }
        // 如果没出错,则输出插入后的文档对象
        console.log(data);
    });
}); // 连接成功回调
mongoose.connection.on('error', () => {
    console.log('连接失败');
}); // 连接失败回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
}); // 连接关闭回调

6.2、字段类型

String:字符串

Number:数字

Boolean:布尔值

Array:数组

Date:日期

Buffer:Buffer对象

Mixed:任意类型,需要使用mongoose.Schema.Types.Mixed指定

ObjectId:对象ID,需要使用mongoose.Schema.Types.ObjectId指定

Decimal128:高精度数字,需要使用mongoose.Schema.Types.Decimal128指定

6.3、字段值验证

6.3.1、必填项

title: {
  type: String,
  required: true
}

6.3.2、默认值

author: {
  type: String,
  default: '匿名'
}

6.3.3、枚举值

sex: {
  type: String,
  enum: ['男', '女']
}

6.3.4、唯一值

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

unique需要重建集合才有效果。永远不要相信用户的输入。

6.4、删除文档

// 导入mongoose
const mongoose = require('mongoose');

// 连接mongoose服务
mongoose.connect('mongodb://127.0.0.1:27017/bilibili'); // 如果bilibili数据库不存在会自动创建

// 设置回调
mongoose.connection.on('open', () => {
    // 创建文档的结构对象,设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name: String,
        author: String,
        price: Number
    });

    // 创建模型对象,对文档操作的封装对象
    let BookModel = mongoose.model('book', BookSchema);

    // 删除一条
    BookModel.deleteOne({_id: '6461be48670777b4e3f2bfcc'}, (err, data) => {
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
    });
    // 批量删除
    BookModel.deleteMany({is_hot: false}, (err, data) => {
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
    });

}); // 连接成功回调
mongoose.connection.on('error', () => {
    console.log('连接失败');
}); // 连接失败回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
}); // 连接关闭回调

6.5、更新文档

// 导入mongoose
const mongoose = require('mongoose');

// 连接mongoose服务
mongoose.connect('mongodb://127.0.0.1:27017/bilibili'); // 如果bilibili数据库不存在会自动创建

// 设置回调
mongoose.connection.on('open', () => {
    // 创建文档的结构对象,设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name: String,
        author: String,
        price: Number
    });

    // 创建模型对象,对文档操作的封装对象
    let BookModel = mongoose.model('book', BookSchema);

    // 更新一条
    // BookModel.updateOne({name: '西游记'}, {price: 9.9}, (err,data) => {
    //     // 判断err
    //     if (err) {
    //         console.log('更新失败');
    //         return;
    //     }
    //     console.log(data);
    // });

    // 批量更新
    BookModel.updateMany({name: '西游记'}, {price: 9.9}, (err,data) => {
        // 判断err
        if (err) {
            console.log('更新失败');
            return;
        }
        console.log(data);
    });

}); // 连接成功回调
mongoose.connection.on('error', () => {
    console.log('连接失败');
}); // 连接失败回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
}); // 连接关闭回调

6.6、查询文档

// 导入mongoose
const mongoose = require('mongoose');

// 连接mongoose服务
mongoose.connect('mongodb://127.0.0.1:27017/bilibili'); // 如果bilibili数据库不存在会自动创建

// 设置回调
mongoose.connection.on('open', () => {
    // 创建文档的结构对象,设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name: String,
        author: String,
        price: Number
    });

    // 创建模型对象,对文档操作的封装对象
    let BookModel = mongoose.model('book', BookSchema);

    // 查询单条
    BookModel.findOne({name: '西游记'}, (err, data) => {
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
    });

    // 根据ID获取文档
    BookModel.findById('6461c222f73d78ca0b9fd980', (err, data) => {
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
    });

    // 批量获取(有条件)
    BookModel.find({author: '吴承恩'}, (err, data) => {
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
    });

    // 无条件,读取所有
    BookModel.find((err, data) => {
        if (err) {
            console.log(err);
            return;
        }
        console.log(data);
    });

}); // 连接成功回调
mongoose.connection.on('error', () => {
    console.log('连接失败');
}); // 连接失败回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
}); // 连接关闭回调

6.7、条件控制

6.7.1、运算符

在mongodb中,不能用><等运算符,要使用替代符号:

  • >,$gt
  • <,$lt
  • >=,$gte
  • <\,$lte
  • !==,$ne
db.students.find({id:{$gt:3}}); id号比3大的所有文档

6.7.2、逻辑运算

$or逻辑或的情况

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

$and逻辑与的情况

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

6.7.3、正则匹配

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

db.students.find({name:/imissyou/});

6.8、mongoose个性化读取

6.7.1、字段筛选

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

6.7.2、数据排序

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

6.7.3、数据截取

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

7、mongodb图形化管理工具

7.1、robo3t

去github上下载,免费

7.2、Navicat

收费

标签:node,console,log,err,Mongodb,文档,mongoose,data
From: https://www.cnblogs.com/luckest/p/17401717.html

相关文章

  • nvm-windows 安装遇到的问题 node目录卸载后(有残留)记得改名
    需求网上好多新项目都需要最新版的node,所有需要切换node版本nvm-windowshttps://github.com/coreybutler/nvm-windows安装步骤-问题删除当前node(当时没删干净)安装nvm-windowsnvminstall16.18.0nvmuse16nvmcurrent(发现没有切换成功)解决问题删除node的时候,目录......
  • 2023/5/15之前关于MongoDB的学习实践
    showdbs/collections/tables;use库创建库db.dropDatabase();删除库db.createCollections('');创建集合db.集合.drop();删除集合db.集合.insertOne/Many集合中插入数据db.集合.remove();删除文档for(leti=x;i<x;i++){}循环操作db.集合.update({条件},{$set:{更改后}})......
  • 2023/5/14 遇到关于mongodb部署的问题
    之前使用关于mongodb5的版本中,linux系统中tar解压mongodb文件夹后的bin目录中mongod是启动mongo服务,而里面默认自带一个连接mongodb的shell脚本mongo而这几天使用mongodb6的版本中发现mongo脚本没有了,去网上查看发现是mongodb发行了一个新的shell脚本工具mongosh,这个需要自己安装......
  • node学习
    1.创建第一个应用使用require引入模块varhttp=require("http");使用http.createServer()创建服务器,并使用listen方法绑定8888端口。函数通过request,response参数来接收和响应数据。varhttp=require('http');http.createServer(function(request,respo......
  • Cassandra HBase和MongoDB性能比较
    这是一篇基于亚马逊云平台上对三个主流的NoSQL数据库性能比较,在读写两个操作不同的组合情况下性能表现不同。横坐标是吞吐量,纵坐标是延迟,这是一对矛盾,吞吐量越大,延迟越低,代表越好。1.纯粹插入,Cassandra领先,见下图:2.WorkloadA:读修改操作各占一半情况下的修改性能:MongoDB明显延迟......
  • 【nodejs基础】Expres编写接口详解05
    一、使用Express写接口浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域接口的跨域问题刚才编写的GET和POST接口,存在一个很严重的问题:不支持跨域请求,解决接口跨域问题的方案主要有两种CORS(主流解决方案,推荐)JSONP(有缺陷:只支持GET请......
  • 多次重新初始化hadoop namenode -format后,DataNode或NameNode没有启动
    多次重新初始化hadoopnamenode-format后,DataNode或NameNode没有启动在搭建完hadoop集群后,需要对主节点进行初始化(格式化)其本质是清理和做一些准备工作,因为此时的HDFS在物理上还是存在的。而且主节点格式化操作只能进行一次。当我们不小心多次初始化,会导致启动hadoop集群时,主......
  • MongoDB 功能详解之时间序列集合(Time Series Collections)
    MongoDB功能详解之时间序列集合(TimeSeriesCollections)      时间序列集合(TimeSeriesCollections):MongoDB5.0版本中的新功能。时间序列数据是一系列数据点,通过分析这些随时间变化的数据点而获得对数据的深刻理解。时间序列数据通常由以下组成部分组成:时间:数......
  • Node.js & Raspberry Pi & WS2812B RGB LEDs strip All In One
    Node.js&RaspberryPi&WS2812BRGBLEDsstripAllInOneNode.js&RaspberryPi&WS2812BRGBLED灯带Node.jshttps://www.w3schools.com/nodejs/nodejs_raspberrypi.aspdemos(......
  • MongoDB基础
    1.MongoDB介绍1.1MongoDB基础说明MongoDB是一个文档数据库(以JSON为数据模型),由C++语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。文档来自于“JSONDocument”,并非我们一般理解的PDF,WORD文档。MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系......