我的数据库表中有一个datetime(name:lud)变量。它以2011-04-11 07:08:02的格式注册。现在我想做一个独特的键与一个文章相结合:文章id+lud。
但是对于唯一的键lud部分,只需要2011-04-11 07:08。
例如:lud 2011-04-11 07:08+文章编号45

最佳答案

作为一个变体-您可以将lud字段的类型更改为VARCHAR并使用index的length选项。
例如:

CREATE TABLE mytable(
  article_id INT(11) DEFAULT NULL,
  lud VARCHAR(19) DEFAULT NULL,
  UNIQUE INDEX UK_mytable (article_id, lud (16))
)
ENGINE = INNODB;

INSERT INTO mytable VALUES
  (1, '2011-04-11 07:08:11');
Query OK, 1 row affected (0.01 sec)

INSERT INTO mytable VALUES
  (1, '2011-04-11 07:09:11');
Query OK, 1 row affected (0.01 sec)

INSERT INTO mytable VALUES
  (1, '2011-04-11 07:09:30');
ERROR 1062 (23000): Duplicate entry '1-2011-04-11 07:09' for key 'UK_mytable'

关于mysql - datetime作为mysql数据库中的唯一键,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8398282/

10-13 09:36