首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >主键实践

主键实践
EN

Stack Overflow用户
提问于 2012-01-10 18:25:49
回答 4查看 82关注 0票数 0
代码语言:javascript
复制
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作为另一个表的外键,我应该只使用它作为主键吗?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-01-10 18:28:39

您必须将id作为主键,因为它是一个AUTO_INCREMENT,并且您正在使用InnoDB。您可以在这两列上创建一个惟一的索引(我将user_id放在第一位),以便在子表外键中使用

票数 2
EN

Stack Overflow用户

发布于 2012-01-10 18:28:50

并不是每个唯一的行组合都应该是主键。您可能可以这样使用它,但这将是一个笨拙的解决方案。

票数 0
EN

Stack Overflow用户

发布于 2012-01-10 18:38:21

显式地将主键标记为主键是一个好主意。

这样,您就不必添加另一个索引,该索引将部分复制您的主键或外键到users表中(尽管后者当前不在那里)。

附注:许多人似乎把身份字段和主键搞混了。标识字段可以很容易地成为主键的一部分(但如果表是InnoDB并且字段是自动递增的整数,则应该是前缀)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8801743

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档