MYSQL中“unsigned attribute”在自增主键中的应用

公司的数据库引入在线审批功能,在创建过程中,提示如下错误:

Set unsigned attribute on auto increment column in table 'alarm_sla'.

经过查阅,发现所有的整数主键都有可选的属性“UNSIGNED”(无符号),顾名思义,无符号整数只能应用与正数的情况下,并且正数的上线大约是有符号正整数上线的2倍(不要问我为什么),对比如下:

类型声明符号取值范围
有符号整数SIGNED-2147483648 ~ 2147483647
无符号整数UNSIGNED0 ~ 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;
  1. 通过修改表定义进行操作
ALTER TABLE alarm_sla AUTO_INCREMENT = 100;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值