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();

  });
相关推荐
2501_9481953415 小时前
RN for OpenHarmony英雄联盟助手App实战:主导航实现
数据库
Filotimo_16 小时前
N+1查询问题
数据库·oracle
fenglllle17 小时前
spring-data-jpa saveall慢的原因
数据库·spring·hibernate
DarkAthena18 小时前
【GaussDB】执行索引跳扫时如果遇到该索引正在执行autovacuum,可能会导致数据查询不到
数据库·gaussdb
短剑重铸之日18 小时前
《7天学会Redis》Day 5 - Redis Cluster集群架构
数据库·redis·后端·缓存·架构·cluster
007php00718 小时前
mySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据
数据库·redis·git·mysql·面试·职场和发展·php
lkbhua莱克瓦2418 小时前
进阶-存储过程3-存储函数
java·数据库·sql·mysql·数据库优化·视图
老邓计算机毕设19 小时前
SSM心理健康系统84459(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·心理健康系统·在线咨询
碎像19 小时前
10分钟搞定 MySQL 通过Binlog 数据备份和恢复
数据库·mysql