【发布时间】:2023-04-01 04:03:01
【问题描述】:
我在INSERT 上收到 1452 错误(如下),但这没有意义。
表格:
# Has parent field
CREATE TABLE IF NOT EXISTS `price_comp_group` (
`id` INT(10) NOT NULL AUTO_INCREMENT,
`headline` VARCHAR(255) NOT NULL,
`text` TEXT NULL,
PRIMARY KEY (`id`)
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB;
# Has child field
CREATE TABLE IF NOT EXISTS `price_comp_group_drug` (
`group_id` INT(10) NOT NULL,
`drug_id` INT(10) UNSIGNED NOT NULL,
`item_order` INT(10) NOT NULL,
CONSTRAINT `fk_group_id_drug` FOREIGN KEY (`group_id`) REFERENCES `price_comp_group`(`id`)
ON DELETE CASCADE,
CONSTRAINT `fk_drug_id_drug` FOREIGN KEY (`drug_id`) REFERENCES `drug`(`ID`)
ON DELETE CASCADE
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB;
# Unique index
ALTER TABLE `price_comp_group_drug`
ADD UNIQUE INDEX idx_group_drug
(`group_id`, `drug_id`);
现在,我正在尝试进行这样的多次插入:
INSERT INTO `price_comp_group_drug` (`group_id`, `drug_id`, `item_order`)
VALUES (1, 1, 1), (1, 2, 3), (0, 3, 6);
我明白了:
#1452 - 无法添加或更新子行:外键约束失败 (dev23_db.price_comp_group_drug, CONSTRAINT fk_group_id_drug FOREIGN KEY (group_id) REFERENCES price_comp_group (id ) 删除级联)
- id = 1 的组存在。
- ID = 1、2、3 的药物存在。
那么为什么我会看到这个错误?如果我尝试使用 没有 有父级的 FOREIGN KEY 值插入/更新行...
【问题讨论】:
-
能不能把药表建表sql?
-
你的 price_comp_group 表在哪里?