nodeJS中使用mongoose模块操作mongodb数据库
在实际运用中,对于数据库的操作我们不可能一直在cmd命令行中进行操作,一般情况下需要在node环境中来操作mongodb数据库,这时就需要引入mongoose模块来对数据库进行增删改查等操作。
首先,启动数据库服务:
mongod --dbpath (db文件夹路径)
然后安装mongoose模块:
npm install mongoose -S
app.js文件:
const mongoose = require('mongoose')
// 连接数据库:如果不存在指定数据库文件则会自动创建(该方法会返回一个promise对象)
mongoose.connect('mongodb://localhost:27017/project',{
useNewUrlParser:true,
useUnifiedTopology:true
}).then( async ()=>{
console.log('数据库连接成功');
}.catch(()=>{
console.log('数据库连接失败');
})
创建模型:(代码均在.then回调函数中执行)
// 先定义数据库中集合的数据格式
let studentSchema = new mongoose.Schema({ // 表示数据库中集合的数据有 name sex age
name:{type:String,require:true},
sex:{type: String},
age:{type: Number,require: true}, // require属性决定该类型数据是否必须存在集合中,为true则必须存在
className:{type: String,default:'中二班'} //default属性设置默认值
})
let Student = mongoose.model("class1",studentSchema) // 简写
let Student = mongoose.model('class1',new mongoose.Schema({
name:String,
sex:String,
age:Number
}))
添加数据
//向集合中插入一条数据 create函数返回的是一个 promise
let result1 = await Student.create({
name:'张三',
sex:'男',
age:20
})
console.log(result1); //向集合中插入多条数据
Student.create([
{
name:'小海',
sex:'男',
age:21
},
{
name:'小菲',
sex:'女',
age:20
},
{
name:'小明',
sex:'男',
age:23
}
])
查询数据
//查询集合中的数据 find函数返回的是一个 promise
let result2 = await Student.find({name:'张三'})
console.log(result2);
删除数据
//删除集合中的一条数据 deleteOne函数返回的也是一个promise
let result3 = await Student.deleteOne({name:'张三'})
console.log(result3); //删除集合中的多条数据 deleteMany函数返回一个promise
let result4 = await Student.deleteMany({name:"张三"})
console.log(result4);
修改数据
//更新一条集合中的数据 updateOne函数返回一个promise
let result5 = await Student.updateOne({name:'小菲'},{$set:{name:'小红'}},)
console.log(result5); //更新多条集合中的数据 updateMany函数返回一个promise
let result6 = await Student.updateMany({name:"小菲"},{$set:{name:'菲菲'}})
console.log(result6);
nodeJS中使用mongoose模块操作mongodb数据库的更多相关文章
- mongoose之操作mongoDB数据库
mongoose是node.js操作mongoDB数据库的一种工具,借助于mongoose,我们可以便捷的完成一些数据库的基本操作,基本使用如下: 1.安装 npm install mongoose ...
- Node.js使用Mongoose包操作MongoDB数据库
1. 安装Mongoose npm install mongoose 2. 使用 2.1 创建连接 var mongoose = require('mongoose'); mongoose.conne ...
- NodeJs连接操作MongoDB数据库
NodeJs连接操作MongoDB数据库 一,介绍 MongoDB是一种文档导向数据库管理系统,由C++撰写而成.介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作. Mongo ...
- mongodb replica set 和 nodejs中使用mongoose连接replica
一.mongodb replication 介绍 官网上的第一句话就是Replication is the process of synchronizing data across multiple ...
- 二十六、Nodejs 操作 MongoDb 数据库
一. 在 Nodejs 中使用 Mongodb 前面的课程我们讲了用命令操作 MongoDB,这里我们看下如何用 nodejs 来操作数据库需要引包: npm install mongodb --sa ...
- C# Asp.net中简单操作MongoDB数据库(二)
C# Asp.net中简单操作MongoDB数据库(一) , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...
- C# Asp.net中简单操作MongoDB数据库(一)
需要引用MongoDB.Driver.dll.MongoDB.Driver.core.dll.MongoDB.Bson.dll三个dll. 1.数据库连接: public class MongoDb ...
- NodeJS操作MongoDB数据库
一.node.js对于mongodb的基本操作 1.数据库的开机 首先我们要先对数据库进行开机的操作,建立一个文件夹用于存放数据库文档.如D:\mongo,接下去在cmd当中键入命令-> mon ...
- koa 基础(二十一)nodejs 操作mongodb数据库 --- 查询数据
1.app.js /** * nodejs 操作mongodb数据库 * 1.安装 操作mongodb * cnpm install mongodb --save * 2.引入 mongodb 下面的 ...
随机推荐
- cnpm与npm指定有什么区别?
CNPM跟NPM用法完全一致,只是在执行命令时将故宫改为CNPM. 因为故宫安装插件是从国外服务器下载,受网络影响大,可能出现异常,如果故宫的服务器在中国就好了,所以我们乐于分享的淘宝团队干了这事来自 ...
- kotlin 之相等判断
在kotlin 中存在二种相等的判断: 1.引用相等 也就是说,两个引用指向同一个对象,使用===操作 ,相反操作为!==来判断 2.结构相等 使用equals 函数相等和==操作符 a?.equal ...
- Throughput Controller(吞吐量控制器) 感觉就像个线程控制器来的
Percent Executions 下的 Throghput 意思是跑总线程的百分之多少. 如 10线程循环一次, Throghput 设置为80,则有8个线程会跑这个请求 Total Execu ...
- Java NIO学习笔记五 FileChannel(文件通道)
Java NIO FileChannel Java NIO FileChannel是连接文件的通道.使用FileChannel,您可以从文件中读取数据和将数据写入文件.Java NIO FileCha ...
- REPLACE 语法
转自:https://www.cnblogs.com/jiangzhengjun/p/4292994.html#_Toc411766043 REPLACE REPLACE [{FIRST OCCURR ...
- 【ASP.NET Core学习】远程过程调用 - gRPC使用
本文介绍在gRPC使用,将从下面几个方面介绍 什么是RPC 什么时候需要RPC 如何使用gRPC 什么是RPC RPC是Remote Procedure Call简称,翻译过来是远程过程调用.它是一个 ...
- JS 事件介绍
1.设置js对象属性为事件处理程序 事件处理程序属性的名字由“on”后面跟着事件名组成.这些属性名 都必须小写 事件处理程序的缺点:设计都是围绕着假设每个事件目标对于每种事件类型将最多只有一个处理程序 ...
- Spring Aop(八)——advisor标签
转发地址:https://www.iteye.com/blog/elim-2396274 8 advisor标签 advisor标签是需要定义在aspect标签里面的,其作用与aspect类似,可以简 ...
- mysql学习笔记11_18(更新、插入和删除)
1.初始表 mysql> select * from department; 2.修改销售部的地点为杭州 mysql> update department set address = '杭 ...
- JAVA数据结构和算法 6 递归
递归:直接或者间接地调用自己.比如计算连续数的阶乘,计算规律:n!=(n-1)!*n. 每个递归方法都有一个基值(终止)条件,以防止无线地递归下去,以及由此引发的程序崩溃. 采用递归是因为它可以从概念 ...