MYSQL四:数据类型(列类型)(数值型整数型)

所谓数据类型:对数据进行统一的分类,从系统的角度出发为了能够使用统一的方式进行管理:更好的利用空间

sql将数据类型分为三大类:数值型,字符串型,时间日期类型
MYSQL四:数据类型(列类型)(数值型整数型)_第1张图片

数值型

数值型数据:都是数值。分为整数型和小数型

整数型
分为5类:

tintint:迷你整型,使用一个字节存储,表示的状态最多为256种

smallint:小整型,使用2个字节存储,表示的状态最多为65536种

mediumint:中整型,使用3个字节存储

int:标准整型,使用4个字节存储

bigint:大整形,使用8个字节存储
MYSQL四:数据类型(列类型)(数值型整数型)_第2张图片

-- 创建一张整型表
create table my_int(
	int_1 tinyint,
    int_2 smallint,
    int_3 int,
    int_4 bigint
)charset utf8;
-- 插入数据
insert into my_int values (100,100,100,100);-- 有效数据
insert into my_int values ('a','b','199','f');-- 无效数据:类型限定
insert into my_int values (255,10000,100000,1000000);-- 错误:超出范围

MYSQL四:数据类型(列类型)(数值型整数型)_第3张图片
SQL中数值类型全部都是默认有符号:分正负,

有时候需要使用无符号数据,限定:int unsigned – 无符号类型:从0开始

-- 给表增加一个无符号类型
alter table my_int add int_5 tinyint unsigned;-- 无符号类型
-- 插入数据
insert into my_int values(127,1000,10000,1000000,255);

MYSQL四:数据类型(列类型)(数值型整数型)_第4张图片
MYSQL四:数据类型(列类型)(数值型整数型)_第5张图片

显示宽度

查看表结构的时候,每个字段的数据类型之后都自带一个括号,括号里面的数字:显示宽度:根据最终显示的位数 如:-123是四位显示宽度(包含符号)

显示宽度:没有特别的含义,只是默认的告诉用户可以显示的形式而已:实际上用户是可以控制的,这种控制不会改变数据本身的大小。

alter table my_int add int_6 tinyint(1) unsigned;-- 指定显示宽度为1
insert into my_int values(127,0,0,0,255,255);

MYSQL四:数据类型(列类型)(数值型整数型)_第6张图片
显示宽度的意义:在于当数据不够显示宽度的 时候,会自动让数据变成对应的显示宽度:通常需要搭配一个前导0来增加宽度,不改变数值大小:zerofill(零填充):零填充会导致数值自动变成无符号

-- 零填充
alter table my_int add int_7 tinyint(2) zerofill;
insert into my_int values(1,1,1,1,1,1,1);
insert into my_int values(100,100,100,100,100,100,100);

MYSQL四:数据类型(列类型)(数值型整数型)_第7张图片
零填充的意义(显示宽度):保证数据格式

你可能感兴趣的:(MYSQL学习笔记含实战操作,mysql,sql,数据库)