史上最简单的MySQL教程(九)「列类型之数值类型」

释放双眼,带上耳机,听听看~!

列类型(数据类型)

所谓的列类型,其实就是指数据类型,即对数据进行统一的分类,从系统的角度出发是为了能够使用统一的方式进行管理,更好的利用有限的空间。

在 SQL 中,将数据类型分成了三大类,分别为:数值型、字符串型和日期时间型。

史上最简单的MySQL教程(九)「列类型之数值类型」

数值型

在 SQL 中,由于要考虑节省磁盘空间的问题,因此系统又将整型细分成五类,分别为:

tinyint:迷你整型,使用 1 个字节存储数据(常用); smallint:小整型,使用 2 个字节存储数据; mediumint:中整型,使用 3 个字节存储数据; int:标准整型,使用 4 个字节存储数据(常用); bigint:大整型,使用 8 个字节存储数据。

接下来,输入如下 SQL 语句进行测试:

— 创建整型表

create table my_int(

int_1 tinyint,

int_2 smallint,

int_3 int,

int_4 bigint

)charset utf8;

史上最简单的MySQL教程(九)「列类型之数值类型」

如上图所示,咱们已经成功创建my_int表,再插入数据:

— 插入数据

insert into my_int values (1,2,3,4);

insert into my_int values ('a','b','c','d');

insert into my_int values (255,2,3,4);

史上最简单的MySQL教程(九)「列类型之数值类型」

如上图所示,通过列类型,咱们可以限定插入数据的类型以及长度范围。

至于为什么在对int_1赋值时,报出超出范围的错误,则是因为在 SQL 中数值类型默认是有符号位的,即分正负。如果需要使用无符号的数据,这就需要咱们自己对数据类型进行声明啦,即在声明数据类型时,追加unsigned关键字。例如:

— 在 my_int 表中,添加 int_5 字段,设置其数据类型为 tinyint unsigned

alter table my_int add int_5 tinyint unsigned;

史上最简单的MySQL教程(九)「列类型之数值类型」

如上图所示,添加int_5字段成功,继续插入数据:

— 插入数据

insert into my_int values (1,2,3,4,255);

史上最简单的MySQL教程(九)「列类型之数值类型」

如上图所示,当咱们将tinyint限定为unsigned之后,已经可以插入0~255之间的任何整数啦!但是,回过头来,让咱们仔细看看下面这张图:

史上最简单的MySQL教程(九)「列类型之数值类型」

通过观察上面这张图,咱们会发现:每个字段的数据类型后面都会跟着一对括号,并且里面含有数字。这些数字啊,其实并没有什么特别的含义,只是表示数据的显示宽度。实际上,咱们可以修改显示的宽度,但是这种修改并不会改变数据本身的大小。

显示宽度的意义:在于当数据不够显示宽度的时候,会自动让数据变成对应的显示宽度,通常需要搭配一个前导0来增加宽度,其不改变数据值的大小,即用zerofill进行零填充,并且零填充会导致数值自动变成无符号。

下面,执行如下 SQL 语句:

— 在 my_int 表中,添加 int_6 字段,设置其数据类型为 tinyint zerofill

alter table my_int add int_6(3) tinyint zerofill;

史上最简单的MySQL教程(九)「列类型之数值类型」

再插入数据,进行测试:

— 插入数据

insert into my_int values (1,2,3,4,5,6);

史上最简单的MySQL教程(九)「列类型之数值类型」

如上图所示,零填充的意义:在于保证数据的格式。

给TA打赏
共{{data.count}}人
人已打赏
安全运维

OpenSSH-8.7p1离线升级修复安全漏洞

2021-10-23 10:13:25

安全运维

设计模式的设计原则

2021-12-12 17:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索