Mysql中数据类型括号中的数字代表的含义
2017-10-18 11:01
621 查看
我们平时用sql语句建数据库的时候,总是会写到int(11),varchar(200)。但是括号里面的值具体代表什么意思呢?我感觉我是’知其然而不知其所以然’。
首先,我们创建一个数据表test:
![](https://img-blog.csdn.net/20171018104731307?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMzE2NDg3NjE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
此处的有符号和无符号怎么区别?
给一个字段加上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:
现在是不是有些清楚了。我们设置的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
首先,我们创建一个数据表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
相关文章推荐
- mysql创建表的时候指定数据类型 括号里面数字代表的含义
- MySQL数据类型char与varchar中数字代表的究竟是字节数还是字符数?
- MySQL数据类型char与varchar中数字代表的究竟是字节数还是字符数?
- mysql 中数据类型tinyint(2)括号中的数字意思
- MySql相关(字符串函数、日期函数、数字函数、数据类型、运算符等)
- mysql中数字类型、日期和时间类型以及字符串(字符)类型及大数据在hibernate中的配置
- mysql中整数类型后面的数字,是不是指定这个字段的长度?比如int(11),11代表11个字节吗?
- mysql 数据类型 phpmyadmin新建字段含义
- MySQL中 数据类型代表字符个数
- Oracle的NULL代表的含义是不确定,那么不确定的东西也会有确定的数据类型吗
- MySQL数据类型 int(M)中M含义
- python学习:不同括号代表的基本内置数据类型
- MySQL 数据类型 在 MySQL 中,有三种主要的类型:文本、数字和日期/时间类型。
- mysql中数据类型的含义
- MySQL的数据类型:文本、数字、日期/时间
- MySQL 三种主要的数据类型类型:文本、数字和日期/时间类型。
- [转]MySQL整数数据的精确数字数据类型
- MySQL数据类型之数字类型详细解析
- mysql - 数据类型后的数字
- MySQL数据类型之数字类型详细解析