Express操作MongoDB【一.Express框架通过Mongoose模块操作MongoDB数据库;二.在接口中间件中使用Mongoose模块】

目录

一.Express框架通过Mongoose模块操作MongoDB数据库

1.MongoDB数据库:

(1)存放数据的格式:key:value

(2)数据库(database)---集合(collection)---文档(document)

(3)是众多NoSQL数据库中的一款:非关系型数据库,不能使用SQL语句对数据库进行操作

2.Mongoose模块

(1)是一个对象模型工具,是对Node.js环境下操作MongoDB数据库进行了封装,可以将MongDB数据库中的数据转换成JavaScript对象供用户使用

(2)名词:

(3)命名规范:驼峰命名,例如:

3.Mongoose模块的使用

(1)安装:npm install mongoose

(2)创建数据库连接文件

(3)创建Schema(表示集合的骨架),再由Schema创建Model

4.mongoose的基本操作

(1)插入文档:save方法

(2)删除文档:findByIdAndDelete,直接通过Model调用,作用是根据文档的_id属性删除

(3)删除文档:deleteOne,直接通过Model调用,根据给定的条件删除文档

(4)更新文档:findOneAndUpdate,直接通过Model调用

        findOneAndUpdate(条件,更新语句,{},回调函数)

(5)updateOne(条件,更新语句,回调函数)

(6)查询所有:find()

(7)按_id查询:findById()

(8)多条件查询:findOne() ===> 返回满足条件的第一条记录

(9)查询集合中的文档数(记录数):count

二.在接口中间件中使用Mongoose模块


一.Express框架通过Mongoose模块操作MongoDB数据库

1.MongoDB数据库:

(1)存放数据的格式:key:value

(2)数据库(database)---集合(collection)---文档(document)

(3)是众多NoSQL数据库中的一款:非关系型数据库,不能使用SQL语句对数据库进行操作

2.Mongoose模块

(1)是一个对象模型工具,是对Node.js环境下操作MongoDB数据库进行了封装,可以将MongDB数据库中的数据转换成JavaScript对象供用户使用

(2)名词:

a.Schema:它是一种以文件形式存储的数据库模型骨架,不具备对数据库操作的能力,仅仅只是数据库在程序片段中的一种表现,可以理解为表结构,实现一种映射。

b.Model:由Schema发布生成的模型,具有抽象属性和行为的数据库操作

c.Entity:由Model创建的实体,它的操作也会影响数据库

(3)命名规范:驼峰命名,例如:

        PersonSchema:Person对应的Schema,Person的文本属性(表结构)

        PersonModel:Person对应的模型。

        PersonEntity:Person对应的实体

Schema生成Model,由Model生成Entity,Model和Entity都可以操作数据库,Model的可操作性更强

3.Mongoose模块的使用

(1)安装:npm install mongoose

(2)创建数据库连接文件

//1.导入mongooose模块
const Mongoose = require('mongoose');
//2.定义MongDB数据库的连接字符串:协议://主机地址:端口号/数据库名
const mdb_url = 'mongodb://localhost:27017/my_test'
//3.建立和MongDB数据库的连接:
// useNewUrlParser:true  是否使用新的url地址转换方式
// useUnifiedTopology:true  是否使用新的用户安全策略
Mongoose.connect(mdb_url,{useNewUrlParser:true,useUnifiedTopology:true})
// 4.对连接过程进行处理
//4.1建立连接-----连接成功会触发connected事件
Mongoose.connection.on('connected',function (){
    console.log('数据库连接成功!!!连接地址是:'+mdb_url)
})
//4.2连接异常------回调函数的参数中保存了异常的信息
Mongoose.connection.on('error',function (err){
    console.log('数据库连接异常!!!'+err)
})
//4.3断开连接
Mongoose.connection.on('disconnected',function (){
    console.log('断开数据库的连接!!!')
})

//5.导出Mongoose
module.exports = Mongoose

(3)创建Schema(表示集合的骨架),再由Schema创建Model

a.Schema:定义的是与集合对应的骨架。Schema中的属性对应的是MongoDB中集合的key

b.Model:是Schema的实例,用于操作MongoDB中的集合中的文档

Express操作MongoDB【一.Express框架通过Mongoose模块操作MongoDB数据库;二.在接口中间件中使用Mongoose模块】_第1张图片

若要指定集合名

Express操作MongoDB【一.Express框架通过Mongoose模块操作MongoDB数据库;二.在接口中间件中使用Mongoose模块】_第2张图片

关于模型名称和数据库中集合名称的对应关系

(1)数据库中没有集合:

mongoose.model('Book',BookSchema) ===> 在模型名后加s就是集合名(不区分大小写)==>books

mongoose.model('Book',BookSchema,'bookinfo') ===> 第三个参数就是用户定义的集合名

(2)数据库中有集合:

mongoose.model('Book',BookSchema,'数据库中已有的集合名') 

4.mongoose的基本操作

(1)插入文档:save方法

        a.先使用Model创建Entity

        b.再使用Entity调用save方法

const Book = require('../model/bookModel')
//1.通过model创建一个对象
const book = new Book({
    bookId:200101,
    bookName:'MongoDB数据库教程',
    publishing:'机械工业出版社',
    publishTime:'2000-12-30',
    price:45,
    count:10
})

//2.通过对象调用save方法向数据库中插入数据
book.save(function (err,res){//err存放的是保存失败后的错误信息,res是保存的对象
    if (err){
        console.log(err)
    }else {
        console.log(res)
    }
})

(2)删除文档:findByIdAndDelete,直接通过Model调用,作用是根据文档的_id属性删除

3.删除bookId为1012的文档
Book.findByIdAndDelete({
    '_id':"6386d1a48aa8b815dc0007e7",
},function (err,data){
    if (err){//err:数据库错误
        console.log('数据库连接失败'+err)
    }else if (data){//若data不为null:表示删除成功
        console.log('删除成功'+data)
    }else if (!data){//若data为null:表示删除失败
        console.log('删除失败'+data)
    }
})

(3)删除文档:deleteOne,直接通过Model调用,根据给定的条件删除文档

Book.deleteOne({
    'bookId':'1013'
},function (err,data){
    if (err){
        console.log('数据库连接失败'+err)
    }else if (data){
        console.log('删除成功'+data)
    }else if (!data){
        console.log('删除失败'+data)
    }
})

(4)更新文档:findOneAndUpdate,直接通过Model调用

        findOneAndUpdate(条件,更新语句,{},回调函数)

Book.findOneAndUpdate({'bookId':1012},//表示查询条件
    {$set:{'count':15}},//更新语句
    null,//表示查询操作,通常为null
    function (err,data){//更新回调函数:err表示数据库的错误信息,data中存放的findOne查询到的文档
    if (err){//err表示数据库错误
        console.log(err)
    }else if (!data){//data为null时,表示没有找到相应的文档
        console.log('未找到相应的数据'+data)
    }else if (data){//data不为null时,表示找到了相应的文档。 data中保存的是更新前的文档
        console.log('更新成功')
    }
})

(5)updateOne(条件,更新语句,回调函数)

Book.updateOne({'bookId':1014},{$set:{'count':222}},
    function (err,data){
        if (err){//err表示数据库错误
            console.log(err)
        }
        console.log(data.modifiedCount)//data是对象,modifiedCount属性表示被更新的记录数,不为0即更新成功
})

(6)查询所有:find()

//查询所有
Book.find(function (err,data){
    if (err){
        console.log(err)
    }
    console.log(data)
})

(7)按_id查询:findById()

//按_id查询:findById()
Book.findById({
    '_id':'200200000010000000000000'
},function (err,data){
    if (err){
        console.log(err)
    }
    console.log(data)
})

(8)多条件查询:findOne() ===> 返回满足条件的第一条记录

Book.findOne({
    'publishing':'机械工业出版社',
    count:'10'
},function (err,data){
    if (err){
        console.log(err)
    }
    console.log(data)
})

(9)查询集合中的文档数(记录数):count

Book.count(function (err,data){
    if (err){
        console.log(err)
    }
    console.log('记录数'+data)
})

二.在接口中间件中使用Mongoose模块

const express = require('express')
const router = express.Router()

const Book = require('../../db/model/bookModel')

//定义查询所有的接口  http://127.0.0.1:3000/mongoapi/findAll
router.get('/findAll',(req, res)=>{
    Book.find((err,data)=>{
        if (err){
            return console.log(err)
        }
        res.json(data)
    })
})

module.exports = router

你可能感兴趣的:(js,数据库,mongodb,前端,javascript,express)