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

layar. Cara terbaik untuk membuat (dan mengelola) indeks di layar-mongo (mongodb)

Karena Anda tidak diperbolehkan menjalankan 'migrate:alter' dalam produksi (meskipun Anda mencoba), salah satu opsi adalah membuat indeks tersebut di file bootstrap ('config/bootstrap.js').

Bayangkan Anda memiliki model Pengguna seperti ini:

var User = {
  attributes: {
    email     : { type: 'string', unique: true, required: true },
    username  : { type: 'string', unique: true, required: true },
    pin: { type: 'string'}
  }
};

module.exports = User;

Kemudian Anda dapat secara manual membuat indeks yang hilang seperti ini di file bootstrap:

module.exports.bootstrap = async function(done) {
  console.log("Loading bootstrap...")

  if (process.env.NODE_ENV === 'test') {

  }

  if (process.env.NODE_ENV === 'production') {
      console.log("CREATING DATABASE INDEX BY HAND")

      // USER MODEL
      var db = User.getDatastore().manager;
      await db.collection(User.tableName).createIndex( { email: 1 }, {unique: true} );
      await db.collection(User.tableName).createIndex( { username: 1 }, {unique: true} );
      // PANDA MODEL
      // db = Panda.getDatastore().manager;
      // await db.collection(Panda.tableName).createIndex( { name: 1 }, {unique: true} );
  }

  // await initializeDatabase() // custom DB initialization...

  return done();
};

Indeks dibuat hanya sekali, proses selanjutnya tidak akan membuat ulang indeks tersebut. pastikan Indeks adalah alias untuk fungsi createIndex dan sudah tidak digunakan lagi.

Referensi:

Referensi pengelola saluran air

MongoDB membuat referensi indeks



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB :menanyakan dokumen dengan dua bidang yang sama, $match dan $eq

  2. Dapatkan Semua 'dokumen' dari 'koleksi' MongoDB

  3. Cara menetapkan batas ukuran array dalam skema Mongoose

  4. Salin/Klon Database di MongoDB

  5. Dan operator mongoosastic (filter)