Уникальное свойство Mongoose по-прежнему позволяет мне сохранить в БД - PullRequest
0 голосов
/ 15 марта 2019

Я предполагаю, что добавление unique: true к полю остановит сохранение в базе данных с тем же значением. Но я все еще могу это сделать.

"мангуст": "^ 5.4.19",

const SessionSchema = new Schema({

    jobId: {
        type: String,
        required: false,
        unique: true,
        index: true,

    },
    productId: {
        type: String,
        required: true,
    },
    status: {
        type: String,
        default: "Pending",
    },
    mode: {
        type: String,
        default: "authentication",
    },
    result: {
        type: Schema.Types.Mixed,
    },
    requests: [RequestSchema],
    callback_at: {
        type: Date,
    },

}, {
        timestamps: { createdAt: "created_at", updatedAt: "updated_at" },
    });

Я уже пытался удалить и восстановить коллекцию. Посмотрите на изображение ниже, я могу создать новую сессию с тем же jobId 1.

enter image description here

public store = async (req: Request, res: Response): Promise<any> => {

        const input = req.body;

        let session = new Session({
            productId: input.productId,
            jobId: input.jobId,
        });

        try {

            session = await session.save();

            const response = {
                success: true,
                status: 201,
                data: { session },
                message: "SESSION CREATED",
            };


            return res.status(response.status).json(response);

        } catch (err) {

            const response = {
                success: false,
                status: 500,
                errors: [],
                message: "UNEXPECTED SESSION ERROR",
            };

            if (err.code === 11000) {
                response.errors.push({
                    code: 11000,
                    message: "Duplicate key error jobId",
                });
            }


            return res.status(response.status).json(response);
        }

db.sessions.getIndex ();

[
    {
        "v" : 2,
        "key" : {
            "_id" : 1
        },
        "name" : "_id_",
        "ns" : "myDB.sessions"
    }
]

Ответы [ 2 ]

5 голосов
/ 15 марта 2019

вы должны понимать, что unique - это опция конфигурации индекса в вашей схеме.

Например, если коллекция 'users' не имеет уникального индекса для userName, вам нужно подождать, пока индекс будет созданпрежде чем начать полагаться на это.

 const user = new mongoose.Schema({
    userName: { type: 'String', unique: true },

  });

    const User = db.model('User', user);

      const doc = new User({
        userName: 'Bob'
      });

      return User.init() // `User.init()` returns a promise that is fulfilled when all indexes are done
        .then(() => User.create(doc))
        .then(() => User.create({ userName: 'Bob' }));
    }
1 голос
/ 15 марта 2019

Я не использовал уникальные должным образом: https://mongoosejs.com/docs/validation.html#the-unique-option-is-not-a-validator

Нужно подождать, пока индексы не будут построены, прежде чем полагаться на уникальность, чтобы быть валидатором.

Я изменил параметры подключения к mongoose, чтобы посмотретькак следующий

 options: {
        useNewUrlParser: true,
        useCreateIndex: true,
        autoIndex: true,
    },

Я не уверен, является ли это наиболее подходящим решением, но это единственное, с чем я столкнулся на данный момент.

...