MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

Menyiapkan koneksi tunggal dengan node.js dan mongo

Inilah yang menggunakan async waiting di singleton. Di db.js saya saya

var MongoClient = require('mongodb').MongoClient;

var DbConnection = function () {

    var db = null;
    var instance = 0;

    async function DbConnect() {
        try {
            let url = 'mongodb://myurl.blablabla';
            let _db = await MongoClient.connect(url);

            return _db
        } catch (e) {
            return e;
        }
    }

   async function Get() {
        try {
            instance++;     // this is just to count how many times our singleton is called.
            console.log(`DbConnection called ${instance} times`);

            if (db != null) {
                console.log(`db connection is already alive`);
                return db;
            } else {
                console.log(`getting new db connection`);
                db = await DbConnect();
                return db; 
            }
        } catch (e) {
            return e;
        }
    }

    return {
        Get: Get
    }
}


module.exports = DbConnection();

Dan di semua modul yang akan menggunakan koneksi yang sama

var DbConnection = require('./db');

async function insert(data) {
    try {
        let db = await DbConnection.Get();
        let result = await db.collection('mycollection').insert(data);

        return result;
    } catch (e) {
        return e;
    }
}


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Manajemen Database Tercanggih:ClusterControl - Panduan

  2. pencarian teks mongodb dengan banyak bidang

  3. mongodb php - cara melakukan kueri seperti INNER JOIN

  4. Bagaimana cara menanyakan dokumen menggunakan bidang _id di driver Java mongodb?

  5. Buat serial satu kelas dalam dua cara berbeda dengan Jackson