如何使用 Sequelize.js 删除外键?

asd*_*van 4 node.js sequelize.js

我知道这可以通过使用像这个问题中使用的原始查询来删除约束来实现,但是,是否有任何内置方法可以从 Sequelize.js 中删除外键?

And*_*tik 6

暂时不 - https://github.com/sequelize/sequelize/issues/5212

在我们的团队中,我们使用这种方法,方法来自QueryGenerator为您添加技巧

let dropFKSQL = queryInterface.QueryGenerator.dropForeignKeyQuery("tableName", "foreignKey")
return queryInterface.sequelize.query(dropForeignKeySQL);
Run Code Online (Sandbox Code Playgroud)

但是带有后缀_ibfk_{index}(由 MySQL 本身)和_idx(由 sequelize)自动生成的外键的差异是一个巨大的痛苦。您可以使用此方法动态获取 FK:

public getForeignKeyName(tableName: string, columnName: string, opts: { queryInterface: QueryInterface }): Promise<string> {
    let sqlz = opts.queryInterface.sequelize;
    let sql = `
        SELECT CONSTRAINT_NAME
        FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE
        WHERE REFERENCED_TABLE_SCHEMA = '${dbSchema}'
          AND TABLE_NAME = '${tableName}'
          AND COLUMN_NAME = '${columnName}'
    `;

    return sqlz.query(sql, { type: sqlz.QueryTypes.SELECT })
        .then((result: { CONSTRAINT_NAME: string }[]) => {
            if (!result || !result[0] || !result[0].CONSTRAINT_NAME) {
                return null;
            }

            return result[0].CONSTRAINT_NAME;
        });
}
Run Code Online (Sandbox Code Playgroud)