MySQL Error 1452 - Невозможно добавить или обновить дочернюю строку: ограничение внешнего ключа не выполнено - PullRequest
3 голосов
/ 24 апреля 2010

Я смотрел на вопросы других людей по этой теме, но, похоже, не могу понять, откуда исходит моя ошибка. Любая помощь будет принята с благодарностью. Я включаю столько, сколько могу придумать, это может помочь найти проблему:

CREATE TABLE stocks (
id INT AUTO_INCREMENT NOT NULL,
user_id INT(11) UNSIGNED NOT NULL,
ticker VARCHAR(20) NOT NULL,
name VARCHAR(20),
rating INT(11),
position ENUM("strong buy", "buy", "sell", "strong sell", "neutral"),
next_look DATE,
privacy ENUM("public", "private"),
PRIMARY KEY(id),
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE
)
 ENGINE=InnoDB DEFAULT CHARSET=utf8;



CREATE TABLE IF NOT EXISTS `stocks_tags` (
  `stock_id` INT NOT NULL,
  `tag_id` INT NOT NULL,
  PRIMARY KEY  (`stock_id`,`tag_id`),
  KEY `fk_stock_tag` (`tag_id`),
  KEY `fk_tag_stock` (`stock_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

ALTER TABLE `stocks_tags`
  ADD CONSTRAINT `fk_stock_tag` FOREIGN KEY (`tag_id`) REFERENCES `tags` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  ADD CONSTRAINT `fk_tag_stock` FOREIGN KEY (`stock_id`) REFERENCES `stocks` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;



CREATE TABLE tags(
id INT AUTO_INCREMENT NOT NULL PRIMARY KEY,
tags VARCHAR(30),
UNIQUE(tags)
)
ENGINE=INNODB DEFAULT CHARSET=utf8;

И ошибка, которую я получаю:

Database_Exception [ 1452 ]: Cannot add or update a child row: a foreign key constraint 
fails (`ddmachine`.`stocks_tags`, CONSTRAINT `fk_stock_tag` FOREIGN KEY (`tag_id`) REFERENCES  
`tags` (`id`) ON DELETE CASCADE ON UPDATE CASCADE) [ INSERT INTO `stocks_tags` (`stock_id`, 
`tag_id`) VALUES (19, 'cash') ]

Я видел, что у кого-то еще была похожая проблема из-за их столбцов enum, но не думаю, что это так.

1 Ответ

4 голосов
/ 24 апреля 2010

Это означает, что tag_id cash отсутствует в таблице тегов ... не должен ли tag_id быть целым числом?

(в этом запросе я имею в виду)

INSERT INTO `stocks_tags` (`stock_id`, `tag_id`) VALUES (19, 'cash')
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...