1

我正在尝试向 Sequel Pro 中的表添加外键(使用 UI)。

我有两个表:“标题”和“类别”,如下所示:

CREATE TABLE `titles` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `title` tinytext NOT NULL,
  `category` varchar(256) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

CREATE TABLE `category` (
  `key` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(256) NOT NULL DEFAULT '',
  PRIMARY KEY (`key`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1;

我想创建一个外键,但我没有尝试过。

类别表应该是一个简单的查找表。我想从大约 6 到 8 个不同的选择中为每个标题分配一个类别。

最初我将类别字段设置为 tinytext,但我会收到错误消息:

“MySQL 错误 1170 (42000):在没有密钥长度的密钥规范中使用了 BLOB/TEXT 列”。

在这里搜索,发现你不能那样使用文本字段,所以我切换到 Varchar 并添加了 256 的长度。现在我得到:

MySQL 说:无法创建表 'lit.#sql-2bf3_2' (errno: 150)。

如何为我的表创建外键?

在 Access 中,这很容易做到。Access 以某种方式将表中的唯一键与查找相关联,但随后隐藏了键并改为显示文本字段。如何使用 Sequel Pro 和 MySQL 获得类似的结果?

编辑:

所以,要澄清这就是我现在所处的位置。我在标题表中的类别字段上添加了一个索引(第一张图片)。

我已将类别表中的“关键”字段更改为 CategoryID(第二张图片)。

但是,我似乎仍然无法创建两个表之间的关系。我犯了同样的错误

这就是我现在所处的位置。

在此处输入图像描述

4

1 回答 1

2

就像category您的查找表一样titles,您需要创建一个索引category来引用外键。它们都需要是相同的数据类型(通常是,尽管有时您可以在某些情况下INT使用变量,但通常不是必需的)。CHAR(2)由于您只期望 6-8 个类别,所以我会成功INT(1)(或者可能INT(2)是安全的)。

在这种情况下,您需要创建类似的东西categoryId,首先需要对其进行索引,然后连接到category似乎不存在的外键;我不确定您是否要使用类似key. 为什么不直接categoryId设置主键category?这样,当您创建titles具有相同名称的外键时,它应该可以正常链接。

编辑:

澄清一点,在您创建之后categoryIDcategory您可以在下面执行此操作titles

ALTER TABLE Orders
ADD CONSTRAINT fk_categoryID
FOREIGN KEY (`categoryId`) REFERENCES `category`(`categoryId`)

编辑:

这是使用原始布局的修改。这应该适合你:

CREATE TABLE IF NOT EXISTS `category` (
  `key` int(2) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(256) NOT NULL DEFAULT '',
  PRIMARY KEY (`key`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=4 ;



CREATE TABLE IF NOT EXISTS `titles` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `title` tinytext NOT NULL,
  `categoryID` int(2) unsigned NOT NULL,
  PRIMARY KEY (`id`),
  KEY `categoryID` (`categoryID`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;


ALTER TABLE `titles`
  ADD CONSTRAINT `titles_ibfk_1` FOREIGN KEY (`categoryID`) REFERENCES `category` (`key`);
于 2015-04-19T04:19:29.593 回答