4.2.Mongoose实现增删查改
中文文档地址: https://cn.mongoosedoc.top/docs/guide.html
#4.2.1.Mongoose是什么?
Mongoose是MongoDB的一个对象模型工具,封装了MongoDB对文档的的一些增删改查等常用方法,让NodeJS操作Mongodb数据库变得更加灵活简单,换句话说就是Mongoose是一个工具,这个工具可以让nodejs操作MongoDB更加方便
在学习之前我们需要注意Mongoose的一个特点,那就是通过关系型数据库的思想来设计非关系型数据库
#4.2.2.准备工作
1.安装mongoose
npm install mongoose --save
2.连接数据库
// 引入mongoose
const mongoose = require('mongoose')
// 连接数据库
mongoose.connect('mongodb://testadmin:[email protected]:27017/test', {useNewUrlParser: true})
3.定义Schema
什么是Schema呢?Schema是mongoose里用到的一种数据模式,可以理解为表结构的定义,举个例子:当我们使用关系型数据库MySQL的时候,我们需要先确定数据库字段,每个字段的类型、是否为空、默认值等等,Schema的定义就是起类似的作用,比如,我需要给user这个文档定义Schema
var UserSchema = mongoose.Schema({
name: String,
age: Number
})
上面就规定了user文档中存的name值必须为字符串类型,age必须为数字类型
下面是支持的类型:
String 字符串
Number 数字
Date 日期
Buffer 二进制
Boolean 布尔值
Mixed 混合类型
ObjectId 对象ID
Array 数组
完整步骤代码:
// 1.引入mongoose
const mongoose = require('mongoose')
// 2.连接数据库
mongoose.connect('mongodb://testadmin:[email protected]:27017/test', {useNewUrlParser: true})
// 3.定义Schema,例如:现在需要操作users集合(表),我们就需要给这个集合定义一个对应的Schema
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
})
#4.2.3.增删查改操作
前面我们定义的Schema只是约定了一种数据模式,并不具备操作数据库的能力,如果想要操作数据库,还需要定义模型:
let User = mongoose.model('User', UserSchema)
通过上面的代码,我们创建出了一个User模型,这个User 模型才具有操作User集合(表)的能力
定义模型注意事项:1、model里面第一个参数的命名要首字母大写 2、这个模型的名字要和数据库中集合(表)的名字对应,默认的对应规则为:如果模型名字最后一位是字母,那么对应数据库中的名字会加s,例如:模型名字为User,那么对应的数据库中的集合名字为users,如果模型名字最后一个是数字,那么和数据库中的集合名字不用加s,例如:模型名字为User1,对应的数据库中的集合名字为user1 3、可以指定模型名称关联的集合,需要写成下面这样
// 指定User模型 对应数据库中user集合
let User = mongoose.model('User', UserSchema, 'user')
#1.增加数据
// 1.引入mongoose
const mongoose = require('mongoose')
// 2.连接数据库
mongoose.connect('mongodb://testadmin:[email protected]:27017/test', {useNewUrlParser: true})
// 3.定义Schema,例如:现在需要操作user集合(表),我们就需要给这个集合定义一个对应的Schema
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
})
// 4.创建模型
let User = mongoose.model('User', UserSchema)
// 5.增加数据
let UserObj = new User({
name: '张三',
age: 20,
status: 0
})
UserObj.save()
#2.查询数据
// 1.引入mongoose
const mongoose = require('mongoose')
// 2.连接数据库
mongoose.connect('mongodb://testadmin:[email protected]:27017/test', {useNewUrlParser: true})
// 3.定义Schema,例如:现在需要操作user集合(表),我们就需要给这个集合定义一个对应的Schema
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
})
// 4.创建模型
let User = mongoose.model('User', UserSchema)
// // 5.增加数据
// let UserObj = new User({
// name: '张三',
// age: 20,
// status: 0
// })
// UserObj.save()
// 6.查询数据
// User.find({}, (err, result) => {
// if (err) {
// console.log(err)
// return
// }
// console.log(result)
// })
#3.更新数据
// 1.引入mongoose
const mongoose = require('mongoose')
// 2.连接数据库
mongoose.connect('mongodb://testadmin:[email protected]:27017/test', {useNewUrlParser: true})
// 3.定义Schema,例如:现在需要操作user集合(表),我们就需要给这个集合定义一个对应的Schema
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
})
// 4.创建模型
let User = mongoose.model('User', UserSchema)
// // 5.增加数据
// let UserObj = new User({
// name: '张三',
// age: 20,
// status: 0
// })
// UserObj.save()
// 6.查询数据
// User.find({}, (err, result) => {
// if (err) {
// console.log(err)
// return
// }
// console.log(result)
// })
// 7.修改数据
User.updateOne({name: "张三"}, {age: 42}, (err, result) => {
if (err) {
console.log(err)
return
}
console.log("更新成功")
})
#4.删除数据
// 1.引入mongoose
const mongoose = require('mongoose')
// 2.连接数据库
mongoose.connect('mongodb://testadmin:[email protected]:27017/test', {useNewUrlParser: true})
// 3.定义Schema,例如:现在需要操作user集合(表),我们就需要给这个集合定义一个对应的Schema
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
})
// 4.创建模型
let User = mongoose.model('User', UserSchema)
// // 5.增加数据
// let UserObj = new User({
// name: '张三',
// age: 20,
// status: 0
// })
// UserObj.save()
// 6.查询数据
// User.find({}, (err, result) => {
// if (err) {
// console.log(err)
// return
// }
// console.log(result)
// })
// 7.修改数据
// User.updateOne({name: "张三"}, {age: 42}, (err, result) => {
// if (err) {
// console.log(err)
// return
// }
// console.log("更新成功")
// })
// 8.删除数据
User.deleteOne({name: '张三'}, (err, result) => {
if (err) {
console.log(err)
return
}
console.log(result)
})
#5.定义Schema的时候可以给默认值
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number,
gender: {
type: String,
default: '男'
}
})