簡體   English   中英

MySQL服務器無法創建復雜的約束

[英]mysql server unable to create complex constraint

我有以下2個表-tree_hierarchy:

tree_hierarchy | CREATE TABLE `tree_hierarchy` (
  `tree_id` int(10) unsigned NOT NULL,
  `time_segment` date NOT NULL,
  `parent_node_id` int(10) unsigned NOT NULL,
  `child_node_id` int(10) unsigned NOT NULL,
  PRIMARY KEY (`tree_id`,`time_segment`,`parent_node_id`,`child_node_id`),
  KEY `fk_tree_hierarchy_child_node_idx` (`child_node_id`,`time_segment`),
  KEY `fk_tree_hierarchy_parent_node_idx` (`parent_node_id`,`time_segment`),
  KEY `fk_tree_hierarchy_tree_id_idx` (`tree_id`),
  KEY `fk_tree_hierarchy_child_def` (`time_segment`),
  CONSTRAINT `fk_tree_hierarchy_tree_id` FOREIGN KEY (`tree_id`) REFERENCES `tree` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8

和node_instance:

node_instance | CREATE TABLE `node_instance` (
  `id` int(10) unsigned NOT NULL,
  `node_id` int(10) unsigned NOT NULL,
  `time_segment` date NOT NULL,
  `name` varchar(128) NOT NULL,
  `sharing` enum('Private','Inherited','User','Open') NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `unique_node_ts` (`time_segment`,`node_id`),
  KEY `fk_node_instance_node_1` (`node_id`),
  KEY `fk_node_instance_time_segment_idx` (`time_segment`),
  CONSTRAINT `fk_node_instance_node_id` FOREIGN KEY (`node_id`) REFERENCES `node` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  CONSTRAINT `fk_node_instance_time_segment` FOREIGN KEY (`time_segment`) REFERENCES `time_segment` (`segment`) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8

嘗試放置約束時:

ALTER TABLE  `tree_hierarchy` ADD CONSTRAINT `fk_tree_hierarchy_child_xyz`
    FOREIGN KEY (`child_node_id` , `time_segment` )
    REFERENCES `node_instance` (`node_id` , `time_segment` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION;

我得到:

ERROR 1005 (HY000): Can't create table 'empty_structure.#sql-4e8_28b1' (errno: 150)

這意味着我的結構不好。 但是我認為這兩個字段(兩個表中的node_id和time_segment都相同)。 創建簡單約束時,一切正常:

ALTER TABLE  `tree_hierarchy` ADD CONSTRAINT `fk_tree_hierarchy_child_abcd`
    FOREIGN KEY (`time_segment` )
    REFERENCES `node_instance` (`time_segment` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION;

Query OK, 0 rows affected (0.41 sec)
Records: 0  Duplicates: 0  Warnings: 0

ALTER TABLE  `tree_hierarchy` ADD CONSTRAINT `fk_tree_hierarchy_child_efgh`
    FOREIGN KEY (`child_node_id` )
    REFERENCES `node_instance` (`node_id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION;

Query OK, 0 rows affected (0.19 sec)
Records: 0  Duplicates: 0  Warnings: 0

我確保外鍵名稱不同(注意xyz,abcd,efgh后綴)。

以前的ADD CONSTRAINT什么問題?

一段時間后,我發現在node_instance中我缺少適當的復雜鍵( node_idtime_segment )。 相反,我有( time_segmentnode_id )-這就是mysql失敗的原因。 添加丟失的密鑰后,一切正常。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM