您的位置:首页 > 数据库 > MySQL

理解MySQL数据类型 避免数据库设计出现混乱

2008-11-23 23:21 435 查看
理解MySQL数据类型避免数据库设计出现混乱
本文突出介绍了MySQL支持的很多重要的数据类型,并介绍如何使用。
数据库存储中的数据类型与大小各异。有些地方只存储数字类型,有些只存储文本类型,有些二者而兼之。而很多数据库支持各种专用类型:日期和时间类型,二进制字符类型以及布尔类型。
选择数据类型与数据相匹配是数据库设计中最为重要的部分,因为这种类型将会影响到RDBMS的效率与性能。所以,对RDBMS的数据类型选择应给予足够的重视。
这就是编写本文的主要目的。表A将列举了MySQL支持的绝大部分重要的数据类型,而MySQL是当前最为流行的免费RDBMS。文中还描述了何时与如何使用这些数据类型。这将有助于建立一个数据库的合理设计。
A
数据类型描述字节推荐使用
TINYINT非常小的整数
有符号值:-128 到127
无符号值:0到255
1
SMALLINT整数,
有符号值:-32768 到32767
无符号值:0到65535
2存储相对比较小的整数。
比如: 年纪,数量
数值前可放一个负号“-”以表示负值。
INT整数,
有符号值:-2147683648 到2147683647(- 231 到231- 1)
无符号值:0到4294967295(0 到232 - 1)
4存储中等整数
例如: 距离
BIGINT不能用SMALLINT 或 INT描述的超大整数。8存储超大的整数
例如: 科学/数学数据
FLOAT单精度浮点型数据4存储小数数据
例如:测量,温度
DOUBLE双精度浮点型数据8需要双精度存储的小数数据
例如:科学数据
DECIMAL用户自定义精度的浮点型数据变量;取决于精度与长度以特别高的精度存储小数数据。
例如:货币数额,科学数据
CHAR固定长度的字符串特定字符串长度(高达255字符)存储通常包含预定义字符串的变量
例如: 定期航线,国家或邮编
VARCHAR具有最大限制的可变长度的字符串变量; 1 + 实际字符串长度 (高达 255 字符)存储不同长度的字符串值(高达一个特定的最大限度).
例如:名字,密码,短文标签
TINYTEXT非常小的文本串
最大尺寸28- 1字节
TEXT没有最大长度限制的可变长度的字符串
最大尺寸216 - 1字节
Variable; 2 +聽 actual string length存储大型文本数据
例如: 新闻故事,产品描述
BLOB二进制字符串
最大尺寸216 - 1字节
变量;2 + 实际字符串长度存储二进制数据
例如:图片,附件,二进制文档
DATE以 yyyy-mm-dd格式的日期3存储日期
例如:生日,产品满期
TIME以 hh:mm:ss格式的时间3存储时间或时间间隔
例如:报警声,两时间之间的间隔,任务开始/结束时间
DATETIME以yyyy-mm-ddhh:mm:ss格式结合日期和时间8存储包含日期和时间的数据
例如:提醒的人,事件
TIMESTAMP以yyyy-mm-ddhh:mm:ss格式结合日期和时间4记录即时时间
例如:事件提醒器,“最后进入”的时间标记
YEAR以 yyyy格式的年份1存储年份
例如:毕业年,出生年
ENUM一组数据,用户可从中选择其中一个
最大尺寸65535 个成员
1或 2个字节存储字符属性,只能从中选择之一
例如:布尔量选择,如性别
SET一组数据,用户可从中选择其中0,1或更多。
最大尺寸64个成员
从1到8字节;取决于设置的大小存储字符属性,可从中选择多个字符的联合。
例如:多选项选择,比如业余爱好和兴趣。
对于一个完整的列表和详细描述,可以查看MySQL manual。你也可以阅读文章Choosing the Right Type for a Column
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: