【mongoose】vue3+vite使用mongoose | mongoose7.0使用

前言

注意

  • 个人认为中文文档仅适合学习参考,英文文档才真正适合项目中使用
  • 因为中文文档可能没有同步官网最新文档。
  • 比如中文文档版本是5.x,但官网最新版文档是7.x,api已不支持回调,改为Promise,若使用了中文文档demo,会抛出各种错误。

操作符参考

操作符参考-https://www.mongodb.com/docs/manual/reference/operator/query/gte/

  • 备用地址 - https://www.mongodb.com/docs/manual/reference/operator/query/gte/

版本号

  • mongodb v6.0.5
  • mongoose v7.1.1

mongoose中文文档 - http://mongoosejs.net/docs/guide.html
mongoose英文文档 - https://mongoosejs.com/docs/subdocs.html


vite配置

  • 配置 "type": "module"

    • 支持
    • 若不配置则不支持es6导入,只能使用 const mongoose= require( "mongoose")
    • 若不配置不支持顶层await参考
  • 参考配置 - 重点第五行

pacgage.json

{
  "name": "myui",
  "version": "0.0.0",
  "private": true,
  "type": "module",
  "scripts": {
    "dev": "vite --host  0.0.0.0",
    "build": "vite build",
    "preview": "vite preview"
  },
  "dependencies": {
    "mongoose": "^7.1.0",
    "vue": "^3.2.45",
    "vue-router": "^4.1.6",
  },
  "devDependencies": {
    "vite": "^4.0.1"
  }
}

mongoose链接数据库

src/service/dbcontent.js

import mongoose from "mongoose"
const db = mongoose.connect('mongodb://127.0.0.1:27017/test')


db.then(mg=> { // 其实参数mg就是mongoose对象
    const { Schema } = mg
     
    console.log(mongoose === mg)//true
    console.log(mongoose.Schema === Schema)//true

}, err => console.log(err))
  • 密码、更多链接方式参考 - https://mongoosejs.com/docs/connections.html

  • 大多数情况数据库链接功能应作为一个模块导出

导出:

src/service/dbcontent.js

import mongoose from "mongoose"
const db = mongoose.connect('mongodb://127.0.0.1:27017/test')

export default db

使用:
重点: 导入import db from "./dbcontent.js" 必须加后缀.js与相对路径./

  • 使用以下方式导入会报错
    • import db from "./dbcontent" 没有.js后缀
    • import db from "dbcontent.js" 没有相对路径./
    • import db from "/dbcontent.js" 没有相对路径./
    • import db from "@/dbcontent.js" 只能是相对路径./

顶层await参考


src/service/app.js

import db from "./dbcontent.js"  

const mg = await db

const { Schema } = mg
const conn = mg.connection

console.log('数据库已连接')

model与Schema

  • model(colName,data) - 创建的模型
    • colName 集合名称,若数据库没有指定的集合名称会自动创建
      • type: String
    • data 添加的数据
      • type: [Object,Array]

  • Schema(config) - 创建模型的规则
    • config - 规则配置
      • type: Object

创建一个model前必须有Schema规则
- Schema是规定model的数据类型
- 若创建的model与规定的Schema规则不符会报错


demo.js

// 连接数据库
import mongoose from "mongoose"
const db = mongoose.connect('mongodb://127.0.0.1:27017/test')

// mg ->  mongoose
const mg = await db //等待数据库连接 
const { Schema } = mg //获取Schema 
const conn = mg.connection //获取connection连接方法

// 1. 创建Schema(制定规则)
const userSchema = new Schema(
    {
        name: String
    }
)

// 2. 创建model,并在集合users中使用userSchema规则
const UserModel = mg.model('users', userSchema)

// 3. 使用UserModel创建实例
const user = new UserModel(
    {
        name: '我是老6呀'
    }
)

// 4. 保存创建的实例,保存失败会报错,成功将返回结果
const userSaveStatu = await user.save()

// 查看创建结果
console.log(userSaveStatu)

// 5. 关闭数据库连接
conn.close()
  • node环境运行

在这里插入图片描述

  • 可直接嵌套Schema
// 在集合users增加数据
const UserModel = mg.model('users', new Schema({
    age: {
        type: Number,//数据类型为Number
        min: 6,//最小值
        max: 251//最大值
    },
    name: {
        type: String,
        trim: true,//是否清空字符串首尾空格
        minlength: 2,//字符串最小长度
        maxlength: 20//字符串最大长度
    },
    sex: {
        type: Number,
        enum: [0, 1],//枚举
        default: 1//默认值
    }
}))

// 保存
const createUser = await new UserModel({
    age: Math.round(Math.random() * (251 - 6)) + 6,
    name: '小米呀',
    sex: Math.round(Math.random())
}).save()

console.log(createUser)

// 关闭连接
conn.close()

node环境运行结果
在这里插入图片描述

删(deleteMany || deleteOne)

const UserModel = mg.model('users', new Schema(
    {
        userName: String,
        pas: String,
        // 嵌套的文档
        posts: [
            new Schema(
                {
                    data: String
                }
            )
        ]
    }
))

// 删除一个
const delUser = await UserModel.deleteOne({ userName: '小林同学' })
// 删除多个 删除age大于等于18的数据
const delMore = await UserModel.deleteMany({ age: { $gte: 18 } })

console.log(delUser)
console.log(delMore)

// 关闭连接
conn.close()
  • 打印结果
    • acknowledged
      • true 删除成功
      • false 删除失败
    • deletedCount 删除数量
{ acknowledged: true, deletedCount: 1 }
{ acknowledged: true, deletedCount: 2 }

常用命令

  1. conn.dropDatabase(dbName) - 删除数据库
    • dbName 数据库名称
      • type : String
    • 返回值
      • Promise
// 删除test数据库
const delDb = await conn.dropDatabase('test')
console.log(delDb);

  1. conn.dropCollection(colName) - 删除数据库
    • colName 集合名称
      • type : String
    • 返回值
      • Promise
// 删除store集合
const delCol = await conn.dropCollection('store')
console.log(delCol);

connection数据库连接事件

  1. connecting 数据库初始链接时
  2. connected 数据库连接成功时,或失去链接重连时。就像我去开车,刚插上车钥匙时
  3. open 已连接数据库,且可操作数据库 。就像我去开车,车已经启动完成,踩下油门就可以跑时
  4. disconnected 与数据库失去链接时,可能是代码显式关闭连接、数据库服务器崩溃或网络连接问题造成。就像我车开着开着就突然熄火了
  5. close 成功关闭数据库时。就像我把车熄火,并拔了车钥匙时
  6. reconnected 与数据库失去连接,并成功重新连接时。就像我车开着开着熄火了,我又重新启动车辆时。
  7. error 连接出错
  8. all 连接到副本集并且Mongoose已成功连接到连接字符串中指定的所有服务器时时

demo.js

import mongoose from "mongoose"

const readUrl = 'mongodb://jxzr:123456@127.0.0.1:27017/juxianz' 
const db = mongoose.connect(readUrl )

conn.on('close',res=>console.log('关闭'))

 setTimeout(() => {
     conn.close()
 }, 1000)
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用mongoose+koa2实现分页查询的示例代码: ``` const Koa = require('koa'); const Router = require('koa-router'); const mongoose = require('mongoose'); // 连接 MongoDB 数据库 mongoose.connect('mongodb://localhost/test', { useNewUrlParser: true }); // 创建 Schema const userSchema = new mongoose.Schema({ name: String, age: Number }); // 创建 Model const UserModel = mongoose.model('User', userSchema); // 创建 Koa 应用和路由 const app = new Koa(); const router = new Router(); // 分页查询接口 router.get('/users', async (ctx, next) => { const page = parseInt(ctx.query.page) || 1; // 当前页码,默认为1 const limit = parseInt(ctx.query.limit) || 10; // 每页显示的记录数,默认为10 const skip = (page - 1) * limit; // 跳过的记录数 const users = await UserModel.find().skip(skip).limit(limit); // 查询指定页数的记录 const total = await UserModel.countDocuments(); // 查询总记录数 const totalPages = Math.ceil(total / limit); // 计算总页数 ctx.body = { page, limit, total, totalPages, data: users }; }); // 启动应用 app.use(router.routes()).use(router.allowedMethods()); app.listen(3000, () => { console.log('Server is running at http://localhost:3000'); }); ``` 在上面的示例中,我们创建了一个名为`users`的接口,通过`ctx.query.page`和`ctx.query.limit`来获取当前页码和每页显示的记录数。然后根据这些参数,使用`skip()`和`limit()`方法来查询指定页数的记录。最后,我们还查询了总记录数,并根据每页显示的记录数计算了总页数。最终返回的数据格式如下: ``` { "page": 1, "limit": 10, "total": 100, "totalPages": 10, "data": [ { "name": "张三", "age": 18 }, { "name": "李四", "age": 20 }, // ... ] } ``` 希望这个示例能够帮助到你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值