MySQL数据类型
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL数据类型,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3159字,纯文字阅读大概需要5分钟。
内容图文
create table int_test(a int zerofill NOT NULL auto_increment, PRIMARY KEY (a)); >createtable int_test_4(a int(4) zerofill NOT NULL auto_increment, PRIMARY KEY (a)); >select * from int_test_4; +------------+ |a | +------------+ | 0001 | | 0002 | |2147483648 | +------------+ >select * from int_test; +------------+ |a | +------------+ |0000000001 | |0000000002 | |2147483648 | +------------+关于浮点数类型:1)能不用到尽量不要用,2)浮点数不能用在等号比较的场景
建议TINYINT替换enum
日期和时间类型
表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。
MySQL5.6不支持year(2)
日期类型注意事项
Timestamp,datatime从MySQL5.6.5支持自动更新为当前的时间:current timestamp
日期转换:cast(datatime_col as DATE)
>select now()+0;
5.6的us支持
>select now(4),MICROSECOND(now(4));
+--------------------------+---------------------+
|now(4) |MICROSECOND(now(4)) |
+--------------------------+---------------------+
|2016-04-16 08:50:01.6589 | 658900 |
+--------------------------+---------------------+
timestamp5.6.6之后支持 null
建议datetime 来替换timestamp
字符串类型
字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这些类型如何工作以及如何在查询中使用这些类型;
字符型
varchar与char的区别
char是一种固定长度的类型,varchar则是一种可变长度的类型,它们的区别是: char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节)varchar存储可变长字符串,小于255字节时需要1个额外字节(大于255需要2个额外字节)存储长度,最大长度为65532字节(所有列总和);
char存储定长,读取时会截断末尾空格,长度最大为255字符;
1)CHAR(M)的涵义:
实际分配的长度是:M*字符编码长度=存储空间
例如:存储了255个字符 中文汉字是占用3个字节
255*3 = 765 一共是765字节
2)varchar(N)中N的涵义
最大存储N个字符;varchar(5)和varchar(200)存储hello所占空间一样,但后者在排序时会消耗更多内存,因为order by col采用fixed_length计算col长度(memory引擎也一样)
例如:
varchar(200)utf8下面占用多少字节
200*3+ 2
varchar(64) utf8
64*3=192<255
192+1=193
建议:
通常使用MySQL是innodb引擎 innodb引擎本来就是变长存储
行存储着:
trx_id, row-id,rollback, filed_pointer, null-flag, filed1,....
innodb存储引擎推荐varchar
char更快是针对MyISAM这种堆表 char 定长分配会更快一点
计算例子
举两个例说明一下实际长度的计算。
a)若一个表只有一个varchar类型,如定义为
createtable t4(c varchar(N)) charset=gbk;
则此处N的最大值为(65535-1-2)/2= 32766。
减1的原因是实际行存储从第二个字节开始’;
减2的原因是varchar头部的2个字节表示长度;
除2的原因是字符编码是gbk。
b)若一个表定义为
createtable t4(c int, c2 char(30), c3 varchar(N)) charset=utf8;
则此处N的最大值为 (65535-1-2-4-30*3)/3=21812
减1和减2与上例相同;
减4的原因是int类型的c占4个字节;
减30*3的原因是char(30)占用90个字节,编码是utf8。
MySQL数据类型
标签:它的 ini 字符串类型 自动更新 led 技术 from family lin
本文系统来源:http://www.cnblogs.com/weiwenbo/p/6531459.html
内容总结
以上是互联网集市为您收集整理的MySQL数据类型全部内容,希望文章能够帮你解决MySQL数据类型所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。