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 接口和异步流程。写几个增删查试试,很快就能用起来。
以上就是如何连接数据库_javascript中mongoose怎么用?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1542334.html
微信扫一扫
支付宝扫一扫