node.js 操作 MongoDB

Node.js 如何连接 MongoDB?

使用 Mongoose ODM 工具
复制代码
npm install mongoose
建立连接
复制代码
// db.js
const mongoose = require("mongoose");
 
mongoose.connect("mongodb://127.0.0.1:27017/mydb")
  .then(() => console.log("MongoDB 连接成功"))
  .catch((err) => console.error("MongoDB 连接失败", err));

说明:

  • 127.0.0.1:27017 是 MongoDB 默认端口
  • mydb 是数据库名,不存在会自动创建

定义数据模型(Model)

复制代码
// model/UserModel.js
const mongoose = require("mongoose");
 
const UserSchema = new mongoose.Schema({
  username: String,
  password: String,
  age: Number
});
 
const UserModel = mongoose.model("user", UserSchema); // 对应集合 users
module.exports = UserModel;

Node.js 操作 MongoDB(CRUD)

所有操作需在 await connect() 后使用,或包裹在 async 函数中。

1️ 添加数据(Create)
复制代码
await UserModel.create({
  username: "Tom",
  password: "123456",
  age: 20
});

查询数据(find)

查询全部

复制代码
const users = await UserModel.find(); 

条件查询

复制代码
const users = await UserModel.find({ age: { $gte: 18 } });

查询一条

复制代码
const user = await UserModel.findOne({ username: "Tom" });
更新数据(Update)
复制代码
await UserModel.updateOne(
  { username: "Tom" },
  { $set: { age: 25 } }
);
删除数据(Delete)
复制代码
await UserModel.deleteOne({ username: "Tom" });

index.js 示例:

复制代码
const connect = require('./db');
const UserModel = require('./model/UserModel');
 
async function main() {
  await connect();
 
  // 添加
  await UserModel.create({ username: "Alice", password: "123", age: 22 });
 
  // 查询
  const users = await UserModel.find();
  console.log(users);
 
  // 更新
  await UserModel.updateOne({ username: "Alice" }, { age: 23 });
 
  // 删除
  await UserModel.deleteOne({ username: "Alice" });
 
  process.exit();
}
 
main();

总结

项目 内容

数据库 MongoDB(非关系型,文档型)

Node连接方式 mongoose.connect()

操作方式 create、find、updateOne、deleteOne

工具推荐 MongoDB Compass、Robo 3T、NoSQLBooster 等

数据结构 文档(Document)、集合(Collection)

常见端口 默认 27017

相关推荐
虹科网络安全17 分钟前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_7717172138 分钟前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
小江的记录本1 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi1 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai2 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw02 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209252 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
ACP广源盛139246256732 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
Elastic 中国社区官方博客3 小时前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索
俺不要写代码3 小时前
数据库:函数
数据库·mysql