首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用Sequelize.js丢弃外键?

如何使用Sequelize.js丢弃外键?
EN

Stack Overflow用户
提问于 2016-08-09 23:10:24
回答 1查看 6.3K关注 0票数 5

我知道这可以通过使用原始查询like the one used in this question to remove a constraint来实现,但是,有什么内置方法可以从Sequelize.js中删除外键吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-27 12:50:38

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

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

代码语言:javascript
复制
let dropFKSQL = queryInterface.QueryGenerator.dropForeignKeyQuery("tableName", "foreignKey")
return queryInterface.sequelize.query(dropForeignKeySQL);

但是自动生成的外键与后缀_ibfk_{index} (由MySQL本身生成)和_idx (通过后置处理)的区别是一个巨大的麻烦。您可以使用此方法动态获取FK:

代码语言:javascript
复制
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;
        });
}
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38861852

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档