ExpressJS - коллекция ошибок дублированного ключа - PullRequest
0 голосов
/ 25 ноября 2018

У меня проблема с этой ошибкой, когда я создаю новое событие с категорией, которая существует в моей базе данных, например, я создал событие с категорией «javascript» и сохранил его в БД, а затем я попытался создать новое событиес категориями "javascript, html, css", а затем я получил эту ошибку дубликат ошибки коллекции ключей

Итак, моя схема для события такова:

    const EventSchema = new Schema({
    title: {
        type: String,
        required: true,
        min: 3,
        max: 100
    },
    featuredImage: {
        type: Object,
    },
    from: {
        type: Date,
        required: true
    },
    to: {
        type: Date,
        required: true
    },
    location: {
        name: {
            type: String
        },
        address: {
            type: Object
        }
    },
    description: {
        type: String
    },
    categories: {
        type: Array,
        trim: true
    },
    featured: {
        type: Boolean
    },
    created_by: {
        type: Schema.Types.ObjectId,
        ref: 'User'
    },
    slug: {
        type: String,
        default: null
    },
    registration: {
        type: Boolean
    },
    tickets: [],
    allday: {
        type: Boolean
    },
    speakers: [{
        type: Schema.Types.ObjectId,
        ref: 'User'
    }],
    attendees: [{
        type: Schema.Types.ObjectId,
        ref: 'User'
    }],
    comments: [CommentSchema]
}, {
    timestamps: true,
    usePushEach: true
});

Так что в основномотправив массив строк, и я получил эту ошибку.

1 Ответ

0 голосов
/ 25 ноября 2018

Возможно, у вас есть индекс , определенный для categories с флагом unique.

Вы можете перечислить существующие индексы с помощью db.events.getIndexes().

. Выможет уронить и воссоздать виновника (будьте осторожны):

> db.events.dropIndex({categories:1})
> db.events.ensureIndex({categories:1},{sparse:true})
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...