更新於 2024/10/06閱讀時間約 8 分鐘

Node.js 程式札記 : MongoDB 資料庫操作

MongoDB 是一個靈活的 NoSQL 資料庫,這篇文章將帶你了解如何在 Node.js 中操作MongoDB 資料庫,包括基本連接、CRUD操作,以及如何使用 Mongoose ODM 來簡化資料庫操作。

連接 MongoDB

首先,我們需要安裝必要的套件。在你的專案目錄中,打開終端機並執行以下指令:

npm init -y
npm install mongodb

現在,讓我們建立一個名為app.js的檔案,並加入以下程式碼來連接MongoDB:

// app.js
const { MongoClient } = require('mongodb');

const url = 'mongodb://localhost:27017';
const dbName = 'myproject';

async function connectToMongo() {
try {
const client = await MongoClient.connect(url);
console.log('Successfully connected to MongoDB');
const db = client.db(dbName);
return db;
} catch (error) {
console.error('Error connecting to MongoDB:', error);
process.exit(1);
}
}

module.exports = { connectToMongo };

這段程式碼建立了一個connectToMongo函式,用於連接到本機MongoDB伺服器。確保你已經安裝並執行了MongoDB。

CRUD 操作

接下來,我們將實現基本的CRUD(建立、讀取、更新、刪除)操作。建立一個名為crudOperations.js的新檔案:

// crudOperations.js
const { connectToMongo } = require('./app');

async function performCRUDOperations() {
const db = await connectToMongo();
const collection = db.collection('users');

// Create
const insertResult = await collection.insertOne({ name: 'John Doe', age: 30 });
console.log('Inserted document:', insertResult.insertedId);

// Read
const findResult = await collection.findOne({ name: 'John Doe' });
console.log('Found document:', findResult);

// Update
const updateResult = await collection.updateOne(
{ name: 'John Doe' },
{ $set: { age: 31 } }
);
console.log('Updated documents:', updateResult.modifiedCount);

// Delete
const deleteResult = await collection.deleteOne({ name: 'John Doe' });
console.log('Deleted documents:', deleteResult.deletedCount);
}

performCRUDOperations().catch(console.error);

這個範例展示了如何執行基本的CRUD操作。你可以透過執行node crudOperations.js來測試這些操作。

使用 Mongoose ODM

Mongoose 可以讓 MongoDB 的使用變得更簡單。首先,安裝 Mongoose :

npm install mongoose

然後,建立一個名為mongooseExample.js的新檔案:

// mongooseExample.js
const mongoose = require('mongoose');

// Connect to MongoDB
mongoose.connect('mongodb://localhost:27017/myproject')
.then(() => console.log('Successfully connected to MongoDB'))
.catch(err => console.error('Error connecting to MongoDB:', err));

// Define model
const User = mongoose.model('User', {
name: String,
age: Number
});

async function mongooseOperations() {
try {
// Create
const user = new User({ name: 'Jane Doe', age: 25 });
await user.save();
console.log('User saved');

// Read
const foundUser = await User.findOne({ name: 'Jane Doe' });
console.log('Found user:', foundUser);

// Update
foundUser.age = 26;
await foundUser.save();
console.log('User updated');

// Delete
await User.deleteOne({ name: 'Jane Doe' });
console.log('User deleted');
} catch (error) {
console.error('Error during operations:', error);
} finally {
// Close connection
await mongoose.connection.close();
console.log('Database connection closed');
}
}

mongooseOperations();

這個範例展示了如何使用 Mongoose 來定義模型並執行 CRUD 操作。執行node mongooseExample.js來測試這些操作。

總結

在這篇文章中,我們學習了如何在 Node.js 中操作MongoDB資料庫。我們從基本的連接開始到原生驅動程式的 CRUD 操作,最後介紹了如何使用 Mongoose ODM 來簡化資料庫操作。這些知識為你開發 Node.js 和 MongoDB 應用程式提供了紮實的基礎。記住,在實際應用中要注意資料驗證、錯誤處理和安全性。

分享至
成為作者繼續創作的動力吧!
© 2024 vocus All rights reserved.