mysql - 为什么我无法在 Sequelize 中保存具有不同列值的多对多表?

标签 mysql database sequelize.js

我有 2 个表,通过交集表具有多对多关系。

产品 --> 订单 <-- 销售点

这就是 Sequelize 生成的内容

CREATE TABLE IF NOT EXISTS `Orders` (`id` INTEGER auto_increment , `amount` INTEGER, `orderDate` DATETIME, `createdAt` DATETIME NOT NULL, `updatedAt` DATETIME NOT NULL, `OutletId` INTEGER, `ProductId` INTEGER, `UserId` INTEGER, UNIQUE `Orders_ProductId_OutletId_unique` (`OutletId`, `ProductId`), PRIMARY KEY (`id`), FOREIGN KEY (`OutletId`) REFERENCES `Outlets` (`id`) ON DELETE SET NULL ON UPDATE CASCADE, FOREIGN KEY (`ProductId`) REFERENCES `Products` (`id`) ON DELETE SET NULL ON UPDATE CASCADE, FOREIGN KEY (`UserId`) REFERENCES `Users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=InnoDB;

我知道它创建了一个唯一键:UNIQUE Orders_ProductId_OutletId_unique (OutletId, ProductId)。

这就是为什么我无法保存它们,它们具有相同的 OutletId 和 ProductId,但是,我的情况,OutletId 和 ProductId 可以相同,但 orderDate 必须不同。

所以我保存这个就可以了,

OrderId, ProductId, OutletId, orderDate
1, 1, 1, '2016-1-1'
2, 2, 1, '2016-1-1'

但是,当我保存另一行时:

1, 1, 1, '2016-1-2'

MySql 给我这个错误:

ERROR 1062: 1062: Duplicate entry '1-1' for key 'Orders_ProductId_OutletId_unique'

好吧,问题是,如何创建具有此验证或约束的模型?

这是我的模型:

订单

'use strict';

module.exports = function(sequelize, DataTypes) {

    var Order = sequelize.define('Order', {
            id: {
                type: DataTypes.INTEGER,
                primaryKey: true,
                autoIncrement: true
            },
            amount: DataTypes.INTEGER,
            orderDate: DataTypes.DATE
        },
        {
            associate: function(models){
                Order.belongsTo(models.Outlet);
                Order.belongsTo(models.Product);
                Order.belongsTo(models.User);
            }
        }
    );

    return Order;
};

产品

'use strict';

module.exports = function(sequelize, DataTypes) {

    var Product = sequelize.define('Product', {
            inventoryCode: DataTypes.STRING,
            name: DataTypes.STRING,
            nameKh: DataTypes.STRING,
            unitKh: DataTypes.STRING,
            unit: DataTypes.STRING,
            monthlyCaseTarget: DataTypes.INTEGER,
            pieces: DataTypes.INTEGER,
            star: DataTypes.BOOLEAN,
            price: DataTypes.FLOAT,
            active: DataTypes.BOOLEAN
        },
        {
            associate: function(models){
                Product.belongsToMany(models.Outlet, {through: models.Order});
                Product.belongsTo(models.Category);
                // Product.hasMany(models.Order);
            }
        }
    );

    return Product;
};

奥特莱斯

'use strict';

module.exports = function(sequelize, DataTypes) {

    var Outlet = sequelize.define('Outlet', {
            outletCode: DataTypes.STRING,
            outletName: DataTypes.STRING,
            outletNameKh: DataTypes.STRING,
            outletSubtype: DataTypes.STRING,
            perfectStoreType: DataTypes.STRING,
            address: DataTypes.STRING
        },
        {
            associate: function(models){
                Outlet.belongsToMany(models.Product, {through: models.Order});
                Outlet.belongsTo(models.Distributor);
                // Outlet.hasMany(models.Order);
            }
        }
    );

    return Outlet;
};

最佳答案

由于sequelize 产生此查询:

UNIQUE Orders_ProductId_OutletId_unique (OutletId, ProductId)

所以我通过将复合唯一键添加到订单列来破解它。

'use strict';

module.exports = function(sequelize, DataTypes) {

    var Order = sequelize.define('Order', {
            id: {
                type: DataTypes.INTEGER,
                primaryKey: true,
                autoIncrement: true
            },
            amount: {
                type: DataTypes.INTEGER
            },
            orderDate: {
                type: DataTypes.DATE,
                unique: 'Orders_ProductId_OutletId_unique'
            }
        },
        {
            associate: function(models){
                Order.belongsTo(models.Outlet);
                Order.belongsTo(models.Product);
                Order.belongsTo(models.User);
            }
        }
    );

    return Order;
};

关于mysql - 为什么我无法在 Sequelize 中保存具有不同列值的多对多表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38914192/

相关文章:

arrays - 将数组保存到数据库 cakephp

node.js - 将 Sequelize 原始查询绑定(bind)到模型

javascript - 如何在 GraphQL 接口(interface)上将模型与 "has one"关系相关联

mysql - 当我在 Commend 提示符下输入 NETSTAT -NA 时,Windows 中 TIME_WAIT 状态的含义是什么?

mysql - 我的 SQL 查询 : Error :Unknown column in field list when using CASE WHEN in WHERE clause

mysql - 以下场景的 SQL 表设计

database - phpMyadmin 给出 token 不匹配错误

mysql - 在mysql中对数字的数字求和

php - 如何阻止行 ID 变大

mysql - 使用 Sequelize 和 MySQL 的地理空间距离计算器