Node.js中操作MongoDB的CRUD操作指南
首先,需要安裝mongodb
驅(qū)動(dòng):
npm install mongodb
接著,可以創(chuàng)建一個(gè)連接到MongoDB的客戶端:
const { MongoClient } = require('mongodb'); const url = 'mongodb://localhost:27017'; // MongoDB服務(wù)地址 const dbName = 'mydatabase'; // 數(shù)據(jù)庫(kù)名稱(chēng) const client = new MongoClient(url); async function main() { await client.connect(); console.log('Connected successfully to server'); const db = client.db(dbName); // 等待在這里執(zhí)行CRUD操作 client.close(); } main().catch(console.error);
基礎(chǔ)版
1. 創(chuàng)建(Create)
插入單條數(shù)據(jù)
async function createDocument(collectionName, doc) { const collection = db.collection(collectionName); const result = await collection.insertOne(doc); console.log(result); } // 使用示例 createDocument('users', { name: 'Tom', age: 25 });
插入多條數(shù)據(jù)
async function createMultipleDocuments(collectionName, docs) { const collection = db.collection(collectionName); const result = await collection.insertMany(docs); console.log(result); } // 使用示例 createMultipleDocuments('users', [ { name: 'Alice', age: 23 }, { name: 'Bob', age: 27 } ]);
2. 讀取(Read)
查詢(xún)單條數(shù)據(jù)
async function findOneDocument(collectionName, query) { const collection = db.collection(collectionName); const doc = await collection.findOne(query); console.log(doc); } // 使用示例 findOneDocument('users', { name: 'Tom' });
查詢(xún)多條數(shù)據(jù)
async function findMultipleDocuments(collectionName, query) { const collection = db.collection(collectionName); const docs = await collection.find(query).toArray(); console.log(docs); } // 使用示例 findMultipleDocuments('users', { age: { $gt: 20 } });
3. 更新(Update)
更新單條數(shù)據(jù)
async function updateOneDocument(collectionName, filter, updateDoc) { const collection = db.collection(collectionName); const result = await collection.updateOne(filter, { $set: updateDoc }); console.log(result); } // 使用示例 updateOneDocument('users', { name: 'Tom' }, { age: 28 });
更新多條數(shù)據(jù)
async function updateMultipleDocuments(collectionName, filter, updateDoc) { const collection = db.collection(collectionName); const result = await collection.updateMany(filter, { $set: updateDoc }); console.log(result); } // 使用示例 updateMultipleDocuments('users', { age: { $lt: 30 } }, { active: true });
4. 刪除(Delete)
刪除單條數(shù)據(jù)
async function deleteOneDocument(collectionName, query) { const collection = db.collection(collectionName); const result = await collection.deleteOne(query); console.log(result); } // 使用示例 deleteOneDocument('users', { name: 'Tom' });
刪除多條數(shù)據(jù)
async function deleteMultipleDocuments(collectionName, query) { const collection = db.collection(collectionName); const result = await collection.deleteMany(query); console.log(result); } // 使用示例 deleteMultipleDocuments('users', { active: true });
完成上面的操作后,確保關(guān)閉數(shù)據(jù)庫(kù)連接。
client.close();
在使用以上代碼時(shí),請(qǐng)通過(guò)替換collectionName
、query
和updateDoc
的值以適配你的實(shí)際需求。
這個(gè)指南涵蓋了在Node.js中使用MongoDB進(jìn)行基本的CRUD操作的代碼示例。在實(shí)際應(yīng)用開(kāi)發(fā)中,你可能需要根據(jù)實(shí)際業(yè)務(wù)邏輯對(duì)其進(jìn)行更復(fù)雜的操作和封裝。
在MongoDB中執(zhí)行更高級(jí)的查詢(xún)和修改操作通常涉及更復(fù)雜的查詢(xún)條件、聚合操作以及對(duì)更新操作的細(xì)致控制。我將在此為您提供一些進(jìn)階使用示例。
進(jìn)階版
高級(jí)查詢(xún)
查詢(xún)時(shí)可以使用更復(fù)雜的操作符,比如$and
, $or
, $in
, $not
, $type
, $regex
等來(lái)構(gòu)建復(fù)雜的查詢(xún)語(yǔ)句。
使用邏輯運(yùn)算符
async function findWithLogicalOperators(collectionName) { const collection = db.collection(collectionName); // 查詢(xún)年齡大于20并且名字以'A'開(kāi)頭的用戶 const query = { $and: [{ age: { $gt: 20 } }, { name: { $regex: /^A/ } }] }; const docs = await collection.find(query).toArray(); console.log(docs); } findWithLogicalOperators('users');
使用數(shù)組查詢(xún)
async function findUsersWithSpecificInterests(collectionName) { const collection = db.collection(collectionName); // 查詢(xún)興趣中包含閱讀的用戶 const query = { interests: "閱讀" }; const docs = await collection.find(query).toArray(); console.log(docs); } findUsersWithSpecificInterests('users');
使用聚合框架(Aggregation Framework)
MongoDB提供的聚合框架可以執(zhí)行更復(fù)雜的數(shù)據(jù)處理任務(wù),比如分組、排序、計(jì)算字段等。
分組和計(jì)算平均年齡
async function averageAgeByInterest(collectionName) { const collection = db.collection(collectionName); const pipeline = [ { $unwind: "$interests" }, { $group: { _id: "$interests", averageAge: { $avg: "$age" } } }, { $sort: { averageAge: -1 } } ]; const result = await collection.aggregate(pipeline).toArray(); console.log(result); } averageAgeByInterest('users');
高級(jí)更新
更新操作可以包括修改字段、添加新字段以及使用更新操作符如$inc
, $push
等。
更新并同時(shí)增加新字段
async function updateAndAddField(collectionName, userId, incrementValue) { const collection = db.collection(collectionName); const filter = { _id: userId }; const updateDoc = { $set: { lastActive: new Date() }, $inc: { loginCount: incrementValue } }; const result = await collection.updateOne(filter, updateDoc); console.log(result); } updateAndAddField('users', "someUserId", 1);
向數(shù)組中添加元素
async function addInterestToUser(collectionName, userId, newInterest) { const collection = db.collection(collectionName); const filter = { _id: userId }; const updateDoc = { $push: { interests: newInterest } }; const result = await collection.updateOne(filter, updateDoc); console.log(result); } addInterestToUser('users', "someUserId", "游泳");
刪除操作
刪除操作同樣可以是條件化的,你可以根據(jù)條件批量刪除記錄。
刪除年齡在一定范圍內(nèi)的用戶
async function deleteUserByAgeRange(collectionName, minAge, maxAge) { const collection = db.collection(collectionName); const query = { age: { $gte: minAge, $lte: maxAge } }; const result = await collection.deleteMany(query); console.log(result); } deleteUserByAgeRange('users', 18, 30);
以上就是Node.js中操作MongoDB的CRUD操作指南的詳細(xì)內(nèi)容,更多關(guān)于Node.js操作MongoDB的CRUD的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
剖析Node.js異步編程中的回調(diào)與代碼設(shè)計(jì)模式
這篇文章主要介紹了Node.js異步編程中的回調(diào)與代碼設(shè)計(jì)模式,雖然大多數(shù)場(chǎng)合回調(diào)編寫(xiě)時(shí)的長(zhǎng)串括號(hào)不怎么好看,但Node的異步性能確實(shí)很好,需要的朋友可以參考下2016-02-02nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼
本篇文章主要介紹了nodejs+mongodb+vue前后臺(tái)配置ueditor的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01node.js中的fs.readlink方法使用說(shuō)明
這篇文章主要介紹了node.js中的fs.readlink方法使用說(shuō)明,本文介紹了fs.readlink方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12Nodejs實(shí)現(xiàn)的一個(gè)靜態(tài)服務(wù)器實(shí)例
這篇文章主要介紹了Nodejs實(shí)現(xiàn)的一個(gè)靜態(tài)服務(wù)器實(shí)例,本文實(shí)現(xiàn)的靜態(tài)服務(wù)器實(shí)例包含cache功能、壓縮功能等,需要的朋友可以參考下2014-12-12Node.js通過(guò)配置?strict-ssl=false解決npm安裝卡住問(wèn)題
使用npm安裝依賴(lài)包是常見(jiàn)的任務(wù)之一,有時(shí)會(huì)遇到安裝卡住的問(wèn)題,本文就來(lái)介紹一下通過(guò)配置?strict-ssl=false解決npm安裝卡住問(wèn)題,感興趣的可以了解一下2024-12-12node.js實(shí)現(xiàn)帶進(jìn)度條的多文件上傳
這篇文章主要為大家詳細(xì)介紹了node.js實(shí)現(xiàn)攜帶進(jìn)度條的多文件上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08