sql >> Database teknologi >  >> NoSQL >> MongoDB

Sejlsjs. Bedste måde at oprette (og administrere) indekser på sails-mongo (mongodb)

Da du ikke har tilladelse til at køre 'migrate:alter' i produktionen (selvom du prøver), er en mulighed at oprette disse indeks i bootstrap-filen ('config/bootstrap.js').

Forestil dig, at du har en brugermodel som denne:

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

module.exports = User;

Så kan du manuelt oprette de manglende indekser som denne i bootstrap-filen:

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();
};

Indekset oprettes kun én gang, efterfølgende kørsler vil ikke genskabe disse indekser. ensureIndex var et alias til createIndex-funktionen, og den er blevet forældet.

Referencer:

Reference for vandlinjeadministrator

MongoDB opret indeksreference



  1. Bedste Session Storage Middleware til Express + MongoDB

  2. Indfødt driverfund fra Mongoose-model returnerer ikke markør

  3. Redis:Race Condition og enkelt gevind

  4. MongoDB - Eksporter data