MySQL的数据类型
来源:互联网 发布:aso如何优化 编辑:程序博客网 时间:2024/06/06 02:20
概述
MySQL支持的数据分为3部分:
- 数值类型
- 日期时间类型
- 字符串类型
先扔一张大图做总结:
数值类型
mysql支持所有标准的SQL中的数值类型
1.整型数值
- 对于整型数值,mysql支持在类型名称后面的小括号内指定显示宽度,例如int(5)表示当数值宽度小于5位时候在数值前面填满宽度,一般配合zerofill属性使用。
- 如果一个列指定为zerofill,则MySQL自动为该列添加unsigned属性。
- 整型的auto_increment用于产生唯一标识符或顺序值。
2.浮点数类型
3.定点数类型
4.位类型
- 小数点表示(浮点数和定点数),定点数(dec)在MySQL内部以字符串形式存放,比浮动数更加精确,适合用来表示货币等精度高的数据。
- 浮点数和定点数可以用在类型名后面加“(m,d)”来表示,其意义为一共显示m位数字,其中d位位于小数点后面,m和d又称为
精度
和标度
。 - 浮点数不写m,d,会自动四舍五入;定点数不写m,d,按照默认值dec(10,0)来操作。
- bit 直接select看不到结果的,可以用bin()或hex()进行读取。
- 在数据量较大时、建议把实数类型转为整数类型。原因很简单:1. 浮点不精确;2.定点计算代价昂贵。例如:要存放财务数据精确到万分之一、则可以把所有金额乘以一百万、然后存在BIGINT下。
- 图片:
日期时间类型
- mysql中用now()写入当前时间。
字符串类型
- char会删除字符串尾部的空格,varchar不会。
- binary类似于char,binary只能保存二进制字符串。
- enum类型忽略大小写。
- text与blob区别:blob保存二进制数据;text保存字符数据,有字符集。
- text和blob不能有默认值。
- 图片:
选择合适的数据类型
- char是固定长度,所以它的处理速度比varchar快得多,但缺点是浪费存储空间,不能在行尾保存空格。在MySQL中,MyISAM建议使用固定长度代替可变长度列;InnoDB建议使用varchar类型,因为在InnoDB中,内部行存储格式没有区分固定长度和可变长度。
- text与blob主要区别是text用来保存字符数据(如文章,日记等),blob用来保存二进制数据(如照片等)。blob与text在执行了大量删除操作时候,有性能问题(产生大量的“空洞“),为提高性能建议定期optimize table 对这类表进行碎片整理。
- 定点与浮点数,对于精度要求较高的地方,使用定点数。
- 日期选择原则是根据实际需求选择满足应用的最小存储日期类型。
阅读全文
0 0
- 【MySQL】MySQL的数据类型
- MYSQL的数据类型
- MySql的数据类型
- mysql的数据类型
- MySQL的一些数据类型
- 数据类型的问题(mysql)
- MySQL支持的数据类型
- MySQL的数据类型
- MySQL的数据类型
- mysql的数据类型 (转)
- mysql 的基本数据类型
- Mysql的基本数据类型
- mysql的数据类型
- mysql的BLOB数据类型
- 常用的MySQL数据类型
- MySQL 的数值数据类型
- mysql常见的数据类型
- 常用的MySQL数据类型
- JS定义函数浅析(一)
- Swing中Frame窗口显示dialog窗口再弹出对话框,背景为白色不显示组件解决办法
- android打包混淆
- maven_setting.xml备份
- 内联汇编
- MySQL的数据类型
- VB操作Excel
- 用SQL命令查看Mysql数据库大小
- rman delete
- Windows 窗体启动和关闭的事件顺序
- MySQL 安全配置
- 遍历磁盘目录代码实例
- 第十章 提纲挈领
- 线程安全与非线程安全