「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Node.js と MongoDB ネイティブ ドライバーを使用した高速かつ柔軟な CRUD API の構築

Node.js と MongoDB ネイティブ ドライバーを使用した高速かつ柔軟な CRUD API の構築

2024 年 8 月 21 日に公開
ブラウズ:209

Building a Fast and Flexible CRUD API with Node.js and MongoDB Native Drivers

MongoDB ネイティブ ドライバーで Node.js と Express を使用する: その理由と方法

Node.js と Express を使用している場合は、MongoDB の人気のある ODM (オブジェクト データ モデリング) ライブラリである Mongoose に遭遇したことがあるかもしれません。 Mongoose は多くの便利な機能を提供しますが、MongoDB のネイティブ ドライバーを直接操作することを選択する理由もあります。この投稿では、MongoDB ネイティブ ドライバーを使用する利点を説明し、MongoDB ネイティブ ドライバーを使用してシンプルな CRUD API を実装する方法を共有します。

MongoDB ネイティブ ドライバーを使用する理由

  1. パフォーマンス: MongoDB ネイティブ ドライバーは、Mongoose が導入する追加の抽象化レイヤーなしで MongoDB と直接対話することで、より優れたパフォーマンスを提供します。これは、高性能アプリケーションにとって特に有益です。

  2. 柔軟性: ネイティブ ドライバーにより、クエリとデータのやり取りをより詳細に制御できます。 Mongoose は、スキーマとモデルを使用して何らかの構造を課しますが、これはすべてのユースケースにとって理想的ではない可能性があります。

  3. オーバーヘッドの削減: ネイティブ ドライバーを使用すると、Mongoose のスキーマとモデルを維持するための追加のオーバーヘッドが回避され、コードベースが簡素化されます。

  4. 学習の機会: ネイティブ ドライバーを直接操作すると、MongoDB の操作をより深く理解できるようになり、素晴らしい学習体験になります。

MongoDB ネイティブ ドライバーを使用した CRUD API の実装

ここでは、Node.js、Express、MongoDB ネイティブ ドライバーを使用してシンプルな CRUD API を設定する方法についてのステップバイステップ ガイドを示します。

1. データベース接続のセットアップ

MongoDB 接続を管理するための utils/db.js ファイルを作成します:

require('dotenv').config()
const dbConfig = require('../config/db.config');
const { MongoClient } = require('mongodb');

const client = new MongoClient(dbConfig.url);

let _db;
let connectPromise;

async function connectToDb() {
    if (!connectPromise) {
        connectPromise = new Promise(async (resolve, reject) => {
            try {
                await client.connect();
                console.log('Connected to the database ?', client.s.options.dbName);
                _db = client.db();
                resolve(_db);
            } catch (error) {
                console.error('Error connecting to the database:', error);
                reject(error);
            }
        });
    }
    return connectPromise;
}

function getDb() {
    if (!_db) {
        throw new Error('Database not connected');
    }
    return _db;
}

function isDbConnected() {
    return Boolean(_db);
}

module.exports = { connectToDb, getDb, isDbConnected };

2. モデルを定義する

MongoDB コレクションと対話するための models/model.js ファイルを作成します:

const { ObjectId } = require('mongodb');
const db = require('../utils/db');

class AppModel {
    constructor($collection) {
        this.collection = null;

        (async () => {
            if (!db.isDbConnected()) {
                console.log('Waiting for the database to connect...');
                await db.connectToDb();
            }
            this.collection = db.getDb().collection($collection);
            console.log('Collection name:', $collection);
        })();
    }

    async find() {
        return await this.collection.find().toArray();
    }

    async findOne(condition = {}) {
        const result = await this.collection.findOne(condition);
        return result || 'No document Found!';
    }

    async create(data) {
        data.createdAt = new Date();
        data.updatedAt = new Date();
        let result = await this.collection.insertOne(data);
        return `${result.insertedId} Inserted successfully`;
    }

    async update(id, data) {
        let condition = await this.collection.findOne({ _id: new ObjectId(id) });
        if (condition) {
            const result = await this.collection.updateOne({ _id: new ObjectId(id) }, { $set: { ...data, updatedAt: new Date() } });
            return `${result.modifiedCount > 0} Updated successfully!`;
        } else {
            return `No document found with ${id}`;
        }
    }

    async deleteOne(id) {
        const condition = await this.collection.findOne({ _id: new ObjectId(id) });
        if (condition) {
            const result = await this.collection.deleteOne({ _id: new ObjectId(id) });
            return `${result.deletedCount > 0} Deleted successfully!`;
        } else {
            return `No document found with ${id}`;
        }
    }
}

module.exports = AppModel;

3. ルートの設定

API ルートを定義するためのindex.js ファイルを作成します:

const express = require('express');
const router = express.Router();

const users = require('../controllers/userController');

router.get("/users", users.findAll);
router.post("/users", users.create);
router.put("/users", users.update);
router.get("/users/:id", users.findOne);
router.delete("/users/:id", users.deleteOne);

module.exports = router;

4. コントローラーの実装

CRUD 操作を処理する userController.js ファイルを作成します:

const { ObjectId } = require('mongodb');
const Model = require('../models/model');

const model = new Model('users');

let userController = {
    async findAll(req, res) {
        model.find()
            .then(data => res.send(data))
            .catch(err => res.status(500).send({ message: err.message }));
    },
    async findOne(req, res) {
        let condition = { _id: new ObjectId(req.params.id) };
        model.findOne(condition)
            .then(data => res.send(data))
            .catch(err => res.status(500).send({ message: err.message }));
    },
    create(req, res) {
        let data = req.body;
        model.create(data)
            .then(data => res.send(data))
            .catch(error => res.status(500).send({ message: error.message }));
    },
    update(req, res) {
        let id = req.body._id;
        let data = req.body;
        model.update(id, data)
            .then(data => res.send(data))
            .catch(error => res.status(500).send({ message: error.message }));
    },
    deleteOne(req, res) {
        let id = new ObjectId(req.params.id);
        model.deleteOne(id)
            .then(data => res.send(data))
            .catch(error => res.status(500).send({ message: error.message }));
    }
}

module.exports = userController;

5. 構成

MongoDB 接続文字列を .env ファイルに保存し、それをロードする db.config.js ファイルを作成します。

module.exports = {
    url: process.env.DB_CONFIG,
};

結論

Mongoose から MongoDB ネイティブ ドライバーへの切り替えは、特定のプロジェクトにとって戦略的な選択となり、パフォーマンス上の利点と柔軟性の向上が得られます。ここで提供される実装は、Node.js および MongoDB ネイティブ ドライバーを使用してアプリケーションの構築を開始するための強固な基盤を提供します。

GitHub で完全なコードを自由にチェックして、独自のプロジェクトのさらなる機能や拡張機能を探索してください。

さらに質問がございましたら、お気軽にコメントしてください。

コーディングを楽しんでください! ?

リリースステートメント この記事は次の場所に転載されています: https://dev.to/jafeer_shaik_f5895990c4ae/building-a-fast-and-flexible-crud-api-with-nodejs-and-mongodb-native-drivers-2i1h?1 侵害がある場合、study_golang @163.comdelete までご連絡ください。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3