公司的数据库引入在线审批功能,在创建过程中,提示如下错误:
Set unsigned attribute on auto increment column in table 'alarm_sla'.
经过查阅,发现所有的整数主键都有可选的属性“UNSIGNED”(无符号),顾名思义,无符号整数只能应用与正数的情况下,并且正数的上线大约是有符号正整数上线的2倍(不要问我为什么),对比如下:
类型 | 声明符号 | 取值范围 |
---|---|---|
有符号整数 | SIGNED | -2147483648 ~ 2147483647 |
无符号整数 | UNSIGNED | 0 ~ 4294967295 |
所以,添加无符号属性的SQL语句如下:
CREATE TABLE `alarm_sla` (
`pk` int UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '主键' ,
PRIMARY KEY (`pk`)
)
ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8
COMMENT='SLA存储表';
如果要指定第增值的起始值,可以有如下两种方式:
1. 通过定义时指明:
CREATE TABLE `alarm_sla` (
`pk` int UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '主键' ,
PRIMARY KEY (`pk`)
)
AUTO_INCREMENT = 100;
- 通过修改表定义进行操作
ALTER TABLE alarm_sla AUTO_INCREMENT = 100;