Node.js 连接 MongoDB

一、使用 `mongodb` 驱动程序

`mongodb` 是 MongoDB 官方提供的 Node.js 驱动,能让你直接与 MongoDB 数据库交互。

1. 安装 `mongodb` 驱动

bash 复制代码
npm install mongodb

2. 连接数据库并进行操作

javascript 复制代码
const { MongoClient } = require("mongodb");

// 数据库连接 URI

const uri = "mongodb://localhost:27017";

// 数据库名称

const dbName = "myDatabase";

// 创建 MongoClient 实例

const client = new MongoClient(uri);

async function run() {

  try {

    // 连接到 MongoDB 服务器

    await client.connect();

    console.log("Connected successfully to server");

    // 选择数据库

    const db = client.db(dbName);

    // 选择集合

    const collection = db.collection("myCollection");

    // 插入一个文档

    const insertResult = await collection.insertOne({ name: "John", age: 30 });

    console.log("Inserted document =>", insertResult);

    // 查询所有文档

    const findResult = await collection.find({}).toArray();

    console.log("Found documents =>", findResult);

  } finally {

    // 关闭连接

    await client.close();

  }

}

run().catch(console.dir);

二、使用 `mongoose` 库

`mongoose` 是一个基于 `mongodb` 驱动的对象数据建模(ODM)库,提供了更高级的抽象和便捷的操作方式。

1. 安装 `mongoose`

bash 复制代码
npm install mongoose

2. 连接数据库并进行操作

javascript 复制代码
const mongoose = require("mongoose");

// 数据库连接 URI

const uri = "mongodb://localhost:27017/myDatabase";

// 连接到 MongoDB

mongoose.connect(uri, {

  useNewUrlParser: true,

  useUnifiedTopology: true,

});

// 获取数据库连接对象

const db = mongoose.connection;

// 监听连接成功事件

db.on("connected", () => {

  console.log("Connected to MongoDB");

});

// 监听连接错误事件

db.on("error", (err) => {

  console.error("MongoDB connection error:", err);

});

// 定义数据模型

const userSchema = new mongoose.Schema({

  name: String,

  age: Number,

});

const User = mongoose.model("User", userSchema);

// 创建一个新用户实例

const newUser = new User({ name: "Jane", age: 25 });

// 保存新用户到数据库

newUser

  .save()

  .then((savedUser) => {

    console.log("Saved user:", savedUser);

    // 查询所有用户

    return User.find({});

  })

  .then((users) => {

    console.log("All users:", users);

    // 关闭数据库连接

    mongoose.disconnect();

  })

  .catch((err) => {

    console.error("Error:", err);

    // 关闭数据库连接

    mongoose.disconnect();

  });
相关推荐
国王不在家19 分钟前
3.5-非关系型数据库-反规范化-sql语言
数据库·nosql
Code季风2 小时前
如果缓存和数据库更新失败,如何实现最终一致性?
数据库·分布式·缓存·微服务·性能优化
outsider_友人A2 小时前
前端也想写后端(2)ORM框架以及数据库关系和操作
node.js·orm·nestjs
Runing_WoNiu2 小时前
mysql 索引失效分析
数据库·mysql
老纪的技术唠嗑局3 小时前
Dify + OceanBase,AI 业务多场景落地实践
数据库·人工智能
可观测性用观测云3 小时前
TDengine 可观测性最佳实践
数据库
余辉zmh3 小时前
【MySQL基础篇】:MySQL索引——提升数据库查询性能的关键
android·数据库·mysql
weixin_419658314 小时前
数据库设计简述
数据库·mysql
数据爬坡ing5 小时前
软件工程总体设计:从抽象到具体的系统构建之道
数据库·流程图·软件工程·可用性测试·软件需求
北方有星辰zz7 小时前
线程的同步与互斥
数据库