DROP TABLE IF EXISTS `media_publications`;
CREATE TABLE `media_publications` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`media_id` int(11) NOT NULL,
`user_id` int(11) NOT NULL,
`date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
`description` varchar(1000) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY (`id`,`user_id`)
) ENGINE=INNODB;在这里将id作为主键是没有意义的吗?考虑到我需要id + user_id作为另一个表的外键,我应该只使用它作为主键吗?
发布于 2012-01-10 18:28:39
您必须将id作为主键,因为它是一个AUTO_INCREMENT,并且您正在使用InnoDB。您可以在这两列上创建一个惟一的索引(我将user_id放在第一位),以便在子表外键中使用
发布于 2012-01-10 18:28:50
并不是每个唯一的行组合都应该是主键。您可能可以这样使用它,但这将是一个笨拙的解决方案。
发布于 2012-01-10 18:38:21
显式地将主键标记为主键是一个好主意。
这样,您就不必添加另一个索引,该索引将部分复制您的主键或外键到users表中(尽管后者当前不在那里)。
附注:许多人似乎把身份字段和主键搞混了。标识字段可以很容易地成为主键的一部分(但如果表是InnoDB并且字段是自动递增的整数,则应该是前缀)。
https://stackoverflow.com/questions/8801743
复制相似问题