繁体   English   中英

Mysql Innodb:自动增量非主键

[英]Mysql Innodb: Autoincrement non-Primary Key

是否可以自动增加非主键?

表“book_comments”

book_id     medium_int
timestamp   medium_int
user_id     medium_int
vote_up     small_int
vote_down   small_int
comment     text
comment_id  medium_int

Primary key -> (book_id, timestamp, user_id)

此表上没有其他索引。 但是,我想使comment_id列自动增量,以便我可以轻松地创建另一个表:

表“book_comments_votes”

comment_id  (medium_int)
user_id     (medium_int)

Primary key -> (comment_id, user_id)

用户只能在每次评论时投票一次。 此表通过主键强制执行此规则。

题:

是否可以自动增加非主键 - 例如,自动增加表“book_comments”中的comment_id列?

替代方案,讨论:

如上所述,我想简单地这样做。 替代方案并不乐观。

  • 通过book_id, timestamp, user_id上的唯一索引创建commnet_id PK并强制执行完整性。 在这种情况下,我会创建一个额外的索引。
  • 保留PK并将book_comments_votes的comment_id替换为整个PK。 这将超过表格的三倍。

建议? 思考?

是的你可以。 您只需要将该列作为索引。

CREATE TABLE `test` (
  `testID` int(11) NOT NULL,
  `string` varchar(45) DEFAULT NULL,
  `testInc` int(11) NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`testID`),
  KEY `testInc` (`testInc`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;


insert into test(
  testID,
 string
)
values (
1,
    'Hello'
);


insert into test( 
testID,
 string
)
values (
2,
    'world'
);

将为'testInc'插入具有自动递增值的行。 然而,这是一件非常愚蠢的事情。

你已经说过正确的方法:

“通过book_id,timestamp,user_id上的唯一索引创建comment_id PK并强制执行完整性。”

这正是你应该这样做的方式。 它不仅为您提供了适合您未来查询所需的主键,还满足了最不惊讶的原则

你现有的桌子。 如果您已经为comment_id提供了主键,唯一的目的是设置auto_increment。 您可以将主键删除到该列。 MySQL允许具有任何键属性的列可以访问auto_increment。 因此,最好像下面那样尝试使用comment_id的索引或unique key

1.删​​除主键

ALTER TABLE `book_comments` MODIFY `comment_id` INT(5) NOT NULL;

ALTER TABLE `book_comments` DROP PRIMARY KEY ;
  1. 使用UNIQUE_KEY属性添加AUTO_INCREMENT

ALTER TABLE 'brand_keywords' CHANGE COLUMN 'comment_id' 'comment_id' INT(5) NOT NULL AUTO_INCREMENT UNIQUE;

从MySQL 5.5开始,似乎可以在没有 索引或 主键的情况下为INT字段提供自动增量。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM