错误1452外键失败

时间:2013-11-19 21:05:53

标签: mysql google-cloud-sql mysql-error-1452

我从MySQL收到1452错误。这是我以前用于INSERT的SQL

INSERT INTO `Quote` (`QTE_id`, `USR_id`, `QTE_total`, `QTE_desc`, `QTE_dateCreated`, `QTE_dateModified`,`QTE_name`, `QTE_status`)

VALUES     (39,2,NULL,'desc','2013-11-19 00:00:00','2013-11-19 11:22:49','test','Active');

Cannot add or update a child row: a foreign key constraint fails (`dbNAME`.`Quote`, CONSTRAINT `USR_id1` FOREIGN KEY (`USR_id`) REFERENCES `users` (`USR_id`)) 

我很肯定我试图将USR_id放入Quote表中。有任何想法吗? Stack Overflow上的很多其他问题都没有回答我的问题。

以下是我试图插入和关联的表格的Create语法(从Workbench生成):

CREATE TABLE `Quote` (
 `QTE_id` int(11) NOT NULL AUTO_INCREMENT,
  `USR_id` int(11) DEFAULT NULL,
  `QTE_total` decimal(7,2) DEFAULT NULL,
  `QTE_desc` text,
  `QTE_dateCreated` timestamp NULL DEFAULT NULL,
  `QTE_dateModified` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `QTE_name` varchar(255) DEFAULT NULL,
  `QTE_status` varchar(30) DEFAULT NULL,
   PRIMARY KEY (`QTE_id`),
   KEY `USR_id1` (`USR_id`),
   CONSTRAINT `USR_id1` FOREIGN KEY (`USR_id`) REFERENCES `users` (`USR_id`)
  ) ENGINE=InnoDB AUTO_INCREMENT=39 DEFAULT CHARSET=utf8;

用户表:

CREATE TABLE `Users` (
 `USR_id` int(11) NOT NULL AUTO_INCREMENT,
  `MGR_id` int(11) NOT NULL DEFAULT '0' 
  `REP_id` int(11) NOT NULL,
  `USR_name` varchar(255) NOT NULL,
  `USR_login` varchar(255) NOT NULL,
  `USR_dateModified` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `USR_dateCreated` datetime NOT NULL,
  `USR_role` enum('Salesperson','Manager') DEFAULT NULL,
  PRIMARY KEY (`USR_id`,`MGR_id`,`REP_id`),
  KEY `MGR_id_idx` (`MGR_id`),
  KEY `REP_id_idx` (`REP_id`),
  KEY `USR_login` (`USR_login`),
  CONSTRAINT `MGR_id` FOREIGN KEY (`MGR_id`) REFERENCES `users` (`USR_id`) ON DELETE NO     ACTION ON UPDATE NO ACTION,
  CONSTRAINT `REP_id` FOREIGN KEY (`REP_id`) REFERENCES `representative` (`REP_id`) ON DELETE NO ACTION ON UPDATE NO ACTION
 ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 

1 个答案:

答案 0 :(得分:0)

我必须做一些小改动(将users更改为Users,在定义MGR_id的行末尾添加',',删除REP_id的约束1}})使两个CREATE工作。

以下是确切的CREATE:

CREATE TABLE `Users` (
 `USR_id` int(11) NOT NULL AUTO_INCREMENT,
  `MGR_id` int(11) NOT NULL DEFAULT '0',
  `REP_id` int(11) NOT NULL,
  `USR_name` varchar(255) NOT NULL,
  `USR_login` varchar(255) NOT NULL,
  `USR_dateModified` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `USR_dateCreated` datetime NOT NULL,
  `USR_role` enum('Salesperson','Manager') DEFAULT NULL,
  PRIMARY KEY (`USR_id`,`MGR_id`,`REP_id`),
  KEY `MGR_id_idx` (`MGR_id`),
  KEY `REP_id_idx` (`REP_id`),
  KEY `USR_login` (`USR_login`),
  CONSTRAINT `MGR_id` FOREIGN KEY (`MGR_id`) REFERENCES `Users` (`USR_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION
 ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;


CREATE TABLE `Quote` (
 `QTE_id` int(11) NOT NULL AUTO_INCREMENT,
  `USR_id` int(11) DEFAULT NULL,
  `QTE_total` decimal(7,2) DEFAULT NULL,
  `QTE_desc` text,
  `QTE_dateCreated` timestamp NULL DEFAULT NULL,
  `QTE_dateModified` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE     CURRENT_TIMESTAMP,
  `QTE_name` varchar(255) DEFAULT NULL,
  `QTE_status` varchar(30) DEFAULT NULL,
   PRIMARY KEY (`QTE_id`),
   KEY `USR_id1` (`USR_id`),
   CONSTRAINT `USR_id1` FOREIGN KEY (`USR_id`) REFERENCES `Users` (`USR_id`)
  ) ENGINE=InnoDB AUTO_INCREMENT=39 DEFAULT CHARSET=utf8;

有了以下两个INSERT就可以了:

mysql> INSERT INTO `Users` (`USR_id`, `MGR_id`) VALUES(2, 2);
Query OK, 1 row affected, 4 warnings (0.22 sec)

mysql> INSERT INTO `Quote` (`QTE_id`, `USR_id`, `QTE_total`, `QTE_desc`, `QTE_dateCreated`, `QTE_dateModified`,`QTE_name`, `QTE_status`) VALUES (39, 2, NULL, 'desc', '2013-11-19 00:00:00', '2013-11-19 11:22:49', 'test', 'Active');
Query OK, 1 row affected (0.22 sec)

我希望这会有所帮助。