Mongoose: Bug avec les index (les index ne sont pas créés)

Créé le 1 juin 2017  ·  3Commentaires  ·  Source: Automattic/mongoose

Salut, j'ai un modèle utilisé pour stocker les likes pour un modèle "news" comme celui-ci :

import mongoose, { Schema } from 'mongoose';
mongoose.set('debug', true);

var newsLikesSchema = new Schema({
  _news_id: { type: Schema.Types.ObjectId, ref: 'news' },
  condominiums_id: { type: Number, required: true },
  users_id: { type: Number, required: true },
  created_at: { type: Date, default: Date.now },
}, {
  emitIndexErrors: true
});

newsLikesSchema.on('error', function(errorE) {
  console.log('---> index error: ', errorE);
});

newsLikesSchema.on('index', function(errI) {
  console.log('----> new index creating', errI);
});

// Index
newsLikesSchema.index({ _news_id: 1, users_id: 1 }, {unique: true}); // unique like per news/nuser
newsLikesSchema.index({ _news_id: 1, created_at: 1 }); // to sort by news_id and date
newsLikesSchema.index({ users_id: 1 });

var newsLikesM = mongoose.model('newslikes', newsLikesSchema);

module.exports = newsLikesM;

Le problème est que les index ne sont pas créés et que je n'ai pas de retour des rappels ".on('error')" et ".on('index')" , ils ne sont pas exécutés.

Version MongoDB : 3.4.2
Version mangouste : 4.10.4
Version de NodeJS : v6.7.0

Commentaire le plus utile

J'ai défini autoIndex:false et j'appelle Model.ensureIndexes() pour créer l'index, mais l'index n'est pas créé. Est-ce lié au problème ?

'use strict';

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var uniqueValidator = require('mongoose-unique-validator');

mongoose.set('debug', true);
mongoose.connect('mongodb://localhost:27017/gh3396',{ config: {autoIndex: false} });

// Variables
var ClientSchema = new Schema(
    {
      name : {
        type     : String,
        required : true,
        trim     : true
      },
      organization : {
        type     : String,
        required : true
      }
    }
  )

// Indexes
ClientSchema.index({ "name" : 1, "organization" : 1 }, { unique : true })

// Plugins
ClientSchema.plugin(uniqueValidator, {
  message : 'Name must be unique.'
})

const Client = mongoose.model('Client', ClientSchema);

Client.ensureIndexes()
Client.on('index', function(err){
console.log(err)
})

new Client({
  name: 'a',
  organization:'a'
}).save().then((result) => {
  console.log(result)
}, (err) => {
  console.log(err)
})

et il crée simplement l'index _id par défaut :

> use gh3396
switched to db gh3396
> show collections
clients
> db.clients.getIndexes()
[
    {
        "v" : 1,
        "key" : {
            "_id" : 1
        },
        "name" : "_id_",
        "ns" : "gh3396.clients"
    }
]

Des idées?
Version MongoDB : 3.2.1
Version mangouste : 4.10.3
Version de NodeJS : v6.7.0

Tous les 3 commentaires

J'ai également eu un problème avec la création d'index. Dans mon cas, il s'agissait de schema.options.autoIndex.
schema.options.autoIndex = false pour mes tables et j'appelle assurerIndexes dans un processus séparé.
Cependant, les index n'ont pas été créés car il vérifiait toujours l'indicateur autoIndex.

Vous pouvez vérifier si #5324 résout votre problème.

J'ai défini autoIndex:false et j'appelle Model.ensureIndexes() pour créer l'index, mais l'index n'est pas créé. Est-ce lié au problème ?

'use strict';

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var uniqueValidator = require('mongoose-unique-validator');

mongoose.set('debug', true);
mongoose.connect('mongodb://localhost:27017/gh3396',{ config: {autoIndex: false} });

// Variables
var ClientSchema = new Schema(
    {
      name : {
        type     : String,
        required : true,
        trim     : true
      },
      organization : {
        type     : String,
        required : true
      }
    }
  )

// Indexes
ClientSchema.index({ "name" : 1, "organization" : 1 }, { unique : true })

// Plugins
ClientSchema.plugin(uniqueValidator, {
  message : 'Name must be unique.'
})

const Client = mongoose.model('Client', ClientSchema);

Client.ensureIndexes()
Client.on('index', function(err){
console.log(err)
})

new Client({
  name: 'a',
  organization:'a'
}).save().then((result) => {
  console.log(result)
}, (err) => {
  console.log(err)
})

et il crée simplement l'index _id par défaut :

> use gh3396
switched to db gh3396
> show collections
clients
> db.clients.getIndexes()
[
    {
        "v" : 1,
        "key" : {
            "_id" : 1
        },
        "name" : "_id_",
        "ns" : "gh3396.clients"
    }
]

Des idées?
Version MongoDB : 3.2.1
Version mangouste : 4.10.3
Version de NodeJS : v6.7.0

Oui, c'est un doublon de #5324 et #5328 . Sera corrigé avec 4.10.6.

Cette page vous a été utile?
0 / 5 - 0 notes