Упорядочить миграцию — добавить проблему ограничения внешнего ключа

Мне нужно удалить существующее ограничение внешнего ключа для столбца и добавить новое ограничение с тем же именем, которое ссылается на первичный ключ другой таблицы.

Я получаю сообщение об ошибке ERROR: Constraint type must be specified through options.type. Хотя я предоставляю тип ограничения в объекте опции в качестве третьего параметра.

Ниже приведен код миграции для справки.

 async up(queryInterface, Sequelize){
    const transaction = await queryInterface.sequelize.transaction();
    try {
      await queryInterface.removeConstraint(
        'shipments',
        'shipments_status_id_fkey',
        { transaction }
      );
      await queryInterface.addConstraint(
        'shipments',
        'status_id',
        {
          type: 'foreign key',
          name: 'shipments_status_id_fkey',
          references: {
            table: 'statuses',
            field: 'id'
          },
          transaction
        }
      );
      await transaction.commit();
    } catch (err) {
      await transaction.rollback();
      throw err;
    }
  }

person Syed Shahwar Shah    schedule 02.07.2020    source источник


Ответы (1)


Документация здесь показывает, что опции должны быть вторым параметром функции addConstraint. https://sequelize.org/master/class/lib/dialects/abstract/query-interface.js%7EQueryInterface.html#instance-method-addConstraint

await queryInterface.addConstraint(
        'shipments',
        {
          type: 'foreign key',
          fields: ['status_id']
          name: 'shipments_status_id_fkey',
          references: {
            table: 'statuses',
            field: 'id'
          },
          transaction
        }
      );
person Subin Sebastian    schedule 02.07.2020
comment
Я использую sequenceize v5 и следую этому документу. sequelize.org/v5/class/ библиотека/ - person Syed Shahwar Shah; 02.07.2020