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

Node.js 如何使用Sequelize.js删除外键?,node.js,sequelize.js,Node.js,Sequelize.js,我知道这可以通过使用原始查询来实现,但是,是否有任何内置方法可以从Sequelize.js中删除外键?暂时不- 在我们的团队中,我们使用这种方法,来自QueryGenerator的方法为您添加了一个技巧 let dropFKSQL = queryInterface.QueryGenerator.dropForeignKeyQuery("tableName", "foreignKey") return queryInterface.sequelize.que

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

暂时不-

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

let dropFKSQL = queryInterface.QueryGenerator.dropForeignKeyQuery("tableName", "foreignKey")
return queryInterface.sequelize.query(dropForeignKeySQL);
但是后缀为
\u ibfk{index}
(由MySQL本身)和
\u 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;
        });
}
publicGetForeignKeyName(tableName:string,columnName:string,选项:{queryInterface:queryInterface}):承诺{
让sqlz=opts.queryInterface.sequelize;
让sql=`
选择约束名称
来自信息\u SCHEMA.KEY\u列\u用法
其中引用的_表_模式=“${dbSchema}”
表_NAME='${tableName}'
和COLUMN_NAME='${columnName}'
`;
返回sqlz.query(sql,{type:sqlz.QueryTypes.SELECT})
.then((结果:{CONSTRAINT_NAME:string}[])=>{
如果(!result | | |!result[0]| |!result[0]。约束_名称){
返回null;
}
返回结果[0]。约束名称;
});
}