MySQL类型属性Unsigned与ZeroFill

本文详细解析了数据库中Unsigned特性的使用及其可能带来的影响,包括其数值范围及与普通整数类型的对比,并通过实例说明了如何避免由Unsigned引发的问题。此外,还介绍了ZeroFill的功能及其应用场景。

1. Unsigned 就是将数字类型无符号化。

int的类型范围是-2147483648~2147483647, int unsigned的类型范围是0~4294967295

Unsigned也可能带来负面的影响,例如:

CREATE TABLE T(a int unsigned,b int unsigned)

INSERT INTO T SELECT 1,2

SElECT a-b FROM T会是什么结果呢,会是-1吗,答案是不确定的,在MAC系统中会报错,

在linux系统中结果为4294967295,所以尽量不要使用unsigned,但是这并不算是bug,可以参考MySQL技术内幕的解释

 

怎样获得-1值呢,只要对SQL_Mode这个参数设置即可

SET SQL_Mode='NO_UNSIGNED_SUBTRACTION';

 

2. ZeroFill,如果宽度小于设定的值则自动填充0

ALTER TABLE T CHANGE a a int(4) unsigned zerofill;

select a from T

结果为0001

转载于:https://www.cnblogs.com/qianlixing/p/4472234.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值