Mongoose 连接 MongoDB 的核心流程是:安装依赖 → 创建连接 → 定义 Schema 和 Model → 增删改查;它是基于 mongodb 原生驱动的高级 ORM 工具,简化数据建模与操作。

在 JavaScript 中用 Mongoose 连接数据库,核心是:安装依赖 → 创建连接 → 定义 Schema 和 Model → 增删改查。它不是直接操作 MongoDB 的驱动(那是 mongodb 原生驱动),而是基于它的高级 ORM 工具,帮你简化数据建模和操作。
安装与基础连接
先确保已安装 Node.js 和 MongoDB(本地或云服务如 MongoDB Atlas)。然后在项目中安装:
npm install mongoose
连接代码通常写在入口文件(如 index.js 或 db.js)里:
立即学习“Java免费学习笔记(深入)”;
// db.js
const mongoose = require('mongoose');
const url = 'mongodb://127.0.0.1:27017/myapp'; // 本地示例
// 或 Atlas 连接字符串:'mongodb+srv://user:pass@cluster.mongodb.net/dbname?retryWrites=true'
mongoose.connect(url, { useNewUrlParser: true, useUnifiedTopology: true })
.then(() => console.log('✅ 数据库连接成功'))
.catch(err => console.error('❌ 连接失败:', err));
定义 Schema 和 Model
Schema 描述文档结构和字段规则,Model 是基于 Schema 编译出的操作接口:
// user.model.js
const mongoose = require('mongoose');
const userSchema = new mongoose.Schema({
name: { type: String, required: true },
email: { type: String, required: true, unique: true },
age: { type: Number, min: 0 }
});
module.exports = mongoose.model('User', userSchema); // 集合名自动变为复数:users
基本 CRUD 操作
导入 Model 后就能增删改查了,所有方法返回 Promise(可 await 或 .then):
-
创建:
User.create({ name: '张三', email: 'zhang@example.com', age: 25 }) -
查询全部:
User.find({});带条件:User.find({ age: { $gte: 18 } }) -
查单个:
User.findOne({ email: 'zhang@example.com' })或User.findById(id) -
更新:
User.findByIdAndUpdate(id, { name: '李四' }, { new: true })(new: true返回更新后数据) -
删除:
User.findByIdAndDelete(id)或User.deleteMany({ age: { $lt: 18 } })
常见注意点
- Mongoose 默认开启
useNewUrlParser和useUnifiedTopology,不加会警告 - 连接成功后才执行操作,建议把业务逻辑放在
mongoose.connect().then(...)里,或用await mongoose.connect(...) - Model 名首字母大写,Mongoose 会自动转为小写复数作为集合名(
User→users) - 字段设
required: true只在 save 时校验,不作用于 update 操作(除非加runValidators: true)
基本上就这些。上手不难,关键是理解 Schema 约束、Model 接口和异步流程。写几个增删查试试,很快就能用起来。










