在实际运用中,对于数据库的操作我们不可能一直在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数据库的更多相关文章

  1. mongoose之操作mongoDB数据库

    mongoose是node.js操作mongoDB数据库的一种工具,借助于mongoose,我们可以便捷的完成一些数据库的基本操作,基本使用如下: 1.安装 npm install mongoose ...

  2. Node.js使用Mongoose包操作MongoDB数据库

    1. 安装Mongoose npm install mongoose 2. 使用 2.1 创建连接 var mongoose = require('mongoose'); mongoose.conne ...

  3. NodeJs连接操作MongoDB数据库

    NodeJs连接操作MongoDB数据库 一,介绍 MongoDB是一种文档导向数据库管理系统,由C++撰写而成.介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作. Mongo ...

  4. mongodb replica set 和 nodejs中使用mongoose连接replica

    一.mongodb replication 介绍 官网上的第一句话就是Replication is the process of synchronizing data across multiple ...

  5. 二十六、Nodejs 操作 MongoDb 数据库

    一. 在 Nodejs 中使用 Mongodb 前面的课程我们讲了用命令操作 MongoDB,这里我们看下如何用 nodejs 来操作数据库需要引包: npm install mongodb --sa ...

  6. C# Asp.net中简单操作MongoDB数据库(二)

    C# Asp.net中简单操作MongoDB数据库(一)    , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...

  7. C# Asp.net中简单操作MongoDB数据库(一)

    需要引用MongoDB.Driver.dll.MongoDB.Driver.core.dll.MongoDB.Bson.dll三个dll. 1.数据库连接: public class MongoDb ...

  8. NodeJS操作MongoDB数据库

    一.node.js对于mongodb的基本操作 1.数据库的开机 首先我们要先对数据库进行开机的操作,建立一个文件夹用于存放数据库文档.如D:\mongo,接下去在cmd当中键入命令-> mon ...

  9. koa 基础(二十一)nodejs 操作mongodb数据库 --- 查询数据

    1.app.js /** * nodejs 操作mongodb数据库 * 1.安装 操作mongodb * cnpm install mongodb --save * 2.引入 mongodb 下面的 ...

随机推荐

  1. Activiti核心API

    ProcessEngine 说明: 1)      在Activiti中最核心的类,其他的类都是由他而来. 2)      产生方式: 在前面看到了两种创建ProcessEngine(流程引擎)的方式 ...

  2. Docker save and load,镜像保存

    一.起因 docker pull 时发生错误 error pulling image configuration: Get https://dseasb33srnrn.cloudfront.net/r ...

  3. linux简单命令6---挂载

  4. Nginx+Keepalived双主架构实现

    Keepalived+Nginx实现高可用Web负载均衡 Master 192.168.0.69 nginx.keepalived Centos7.4backup 192.168.0.70 nginx ...

  5. 使用 mencoder 制作幻灯片

    首先安装相关依赖: sudo apt-get install mencoder sudo apt-get install imagemagick 编辑 test.sh 脚本如下: #!/bin/bas ...

  6. 极客时间-左耳听风-程序员攻略-Java底层知识

    Java 字节码相关 字节码编程,也就是动态修改或是动态生成 Java 字节码.Java 的字节码相当于汇编,其中的一些细节. Java Zone: Introduction to Java Byte ...

  7. 中国行政区划表,包括34个省、直辖市的所有数据 mysql数据

    中国行政区划表,包括34个省.直辖市的所有数据 sql文件地址 https://gitee.com/zwh_9527/ChinaProvince

  8. 日记 进程 ip /端口

    查看日记: tail -f  log.txt       循环查看 cat  info         查看文件 less info           查看文件 head -n 10 /vv/v  ...

  9. eduSOHO 首页模板 全部课程模块代码

    首页模板文件 设置在后台主题-管理-选中网校课程 然后前台调用代码 {% if code != 'course-grid-with-condition-index' %}        {% cach ...

  10. go 计算 MD5

    Golang的加密库都放在crypto目录下,其中MD5库在crypto/md5包中,该包主要提供了New和Sum函数 直接调用md5计算 package main import ( "cr ...