Mysql中数据类型括号中的数字代表的含义

来源:互联网 发布:新路由器有信号没网络 编辑:程序博客网 时间:2024/04/30 03:43

我们平时用sql语句建数据库的时候,总是会写到int(11),varchar(200)。但是括号里面的值具体代表什么意思呢?我感觉我是’知其然而不知其所以然’。

首先,我们创建一个数据表test:

mysql> CREATE TABLE test(    -> id1 int(1),    -> id2 tinyint(1)    ->);

这里写图片描述

此处的有符号和无符号怎么区别?
给一个字段加上UNSIGNED属性,该字段类型就是带符号的,比如tinyint,带UNSIGNED属性,这个字段就可以存0~255的值,如果没有UNSIGNED属性,就只能存-128~127之间的值


上述表格中的数值类型都是定长的,也就是说,无论你存的数值是多少,多大或者多小,占用的字节大小都是固定的。例如,之前设置的int(1),虽然M值是1个字符,但是它所占用的空间大小永远都是4个字节的大小,换句话说就是,你可以存入有符号整型从-2 147 483 648到2 147 483 647包括这两个数的中间任何一个数。int(1)和int(11)占用的是4个字节,可以存入上述这些数,tinyint(1)和tinyint(4)占用的是1个字节,可以存入从-128到127的数,这也是为什么之前的一次试验,int(1)插入128成功,而tinyint(1)插入128却提示超出长度。

那么,这个M值到底代表什么意思呢?

到这里,我们已经可以发现,M值即使设置为1,它也可以存入字符长度大于1的值,那么,如果存入的字符长度小于1会怎么样?我们来试一试:

先将id1的类型更改为int(2),然后插入数据id1=1:

mysql> ALTER TABLE test Modify id1 int(2);mysql> INSERT INTO test(id1) values(1);//运行成功,说明值1已经插入到test表中
mysql> SELECT * FROM test;+------+|  id1 |+------+|   1  |+------+//接下来,我们再修改一下id1的填充数据类型zerofill(表示用0填充),这里先知道如何操作即可,我们再从结果得出结论:mysql> ALTER TABLE test MODIFY id1 int(2) zerofill;mysql> SELECT * FROM test;+------+|  id1 |+------+|  01  |+------+

现在是不是有些清楚了。我们设置的M值是2,没有设置zerofill用0填充时,对于操作没有任何影响,而设置了zerofill后,我们可以清楚地看到值1字符数不足M值,左前位置补0。我们也可以将M值设置成别的大小进行多次测试,这里就不进行测试了。

需要强调的是,不同的数据类型中的M值意义是不一样的,我们这里仅讨论整型中的M值。

从上面我们可以得到如下的结论:

1、整数型的数值类型已经限制了取值范围,有符号整型和无符号整型都有,而M值并不代表可以存储的数值字符长度,它代表的是数据在显示时显示的最小长度;

2、当存储的字符长度超过M值时,没有任何的影响,只要不超过数值类型限制的范围;

3、当存储的字符长度小于M值时,只有在设置了zerofill用0来填充,才能够看到效果,换句话就是说,没有zerofill,M值就是无用的。

总结:int(11),tinyint(1),bigint(20),后面的数字,不代表占用空间容量。而代表最小显示位数。这个东西基本没有意义,除非你对字段指定zerofill。

所以我们在设计mysql数据库时,建表时,mysql会自动分配长度:int(11)、tinyint(4)、smallint(6)、mediumint(9)、bigint(20)。

所以,就用这些默认的显示长度就可以了。不用再去自己填长度,比如搞个int(10)、tinyint(1)之类的,基本没用。而且导致表的字段类型多样化。

字符和字节的概念。

字节(Byte)是一种计量单位,表示数据量多少,它是计算机信息技术用于计量存储容量的一种计量单位。

字符是指计算机中使用的文字和符号,比如1、2、3、A、B、C、~!·#¥%……—*()——+、,中,国等等。

字符和字节不存在绝对的关系,只是在不同的编码格式里,对应的比值不一样。比如:

1.UTF-8编码中,一个英文字符等于一个字节,一个中文(含繁体)字符等于三个字节。

2.Unicode编码中,一个英文等于两个字节,一个中文(含繁体)字符等于两个字节。

符号:英文标点占一个字节,中文标点占两个字节。举例:英文句号“.”占1个字节的大小,中文句号“。”占2个字节的大小。

3.UTF-16编码中,一个英文字母字符或一个汉字字符存储都需要2个字节(Unicode扩展区的一些汉字存储需要4个字节)。

4.UTF-32编码中,世界上任何字符的存储都需要4个字节。

所有你看见的单个字:a,啊,都叫字符。

http://www.cnblogs.com/stringzero/p/5707467.html

阅读全文
0 0
原创粉丝点击