MySQL数据类型

来源:互联网 发布:淘宝网充值平台2016 编辑:程序博客网 时间:2024/06/05 19:51

数值类型

数值类型大致可分为两种:一个是整数,一个是浮点数或小数;

整数类型常用的为int类型,允许范围在(-2147483648,2147483648)之间。

浮点数或小数常用类型有:float,double和decimal类型。

float类型(单精度浮点数值),double类型(双精度浮点数值),decimal类型(用于要求非常高的精确度计算中,这些类型允许指定数值的精确度和计数方法作为选择参数。精确度在这里是指为这个值保存的有效数字的总个数,而计数方法表示小数点后数字的个数)

  1. create table data(age float(5,2));
  2. insert into data(45.678);//结果保留两位小数,四舍五入,结果为45.68

字符串类型

常用字符串类型有:charvarchartextblob类型

char类型:用于定长字符串,必须在圆括号内用一个大小修饰符来定义,这个大小修饰符范围为0到255,指定了要存储的值的长度。

varchar类型:是char类型的变体,用于变长字符串,也也必须带有一个范围在0到255之间的大小指示器,区别在于MySQL处理这个指示器的方式:char把这个大小视为值的的准确大小,而varchar类型把它视为最大值并且只使用了存储字符串实际上需要的字节数。所以如果不能确定字段要存储多少个字符时,使用这种类型是一个很好的选择。

对于比较长的字符串,MySQL提供了text和blob两种类型,根据要存储数据的大小,它们都有不同的子类型,用于存储图像,大的文本,声音文件那样的二进制数据。区别在于:blob类型区分大小写,text类型不区分。

日期时间类型

MySQL用dateyear类型描述简单的日期值,使用time类型描述时间值。这些值可以描述为字符串或不带分隔符的整数序列。如果描述为字符串,date类型的值应该使用连字号作为分隔符分隔开,而time类型的值应该使用冒号作为分隔符分隔开。year类型的值必须用4个数字存储,MySQL会自动转换:把00~69范围内的值转换到2000~2069范围内,而把70~99范围内的值抓换到1970~1999之内。如下例:

  1. create table data(showtime time,birthday date,graduation year);
  2. insert into data values('12:02:02','2000-02-02',2002),(120202,20000202,02);//结果是一样的

除了日期和时间数据类型,MySQL还支持一种混合类型:datetimetimestamp数据类型,它们可以把日期和时间作为一个单值的组成成分来存储。这两种类型通常用于自动存储包含当前日期和时间的时间戳,并且对执行大量数据库事务和需要建立一个调试和审查用途的审计跟踪的应用程序可以派上用场。

如果一个行中第一个字段语句为timestamp类型,而且这个字段没有被明确指定值或被指定了一个null值, MySQL将会自动用当前日期和时间填充它。

使用MySQL的now()函数在语句为datetime类型的字段中填充当前的日期和时间可以得到相同的结果。


数据类型选择

数据分类在使存储数据更有一致性和提高效率和速度方面起了重要的作用。从而,当设计一个数据库时对数据类型的选取不能掉以轻心,并且从MySQL可以使用的多组选项做出选择之前,应该对所有涉及的问题做出充分考虑。

下面列出对MySQL选取数据类型需要牢记的几个标准:

允许值,允许输入一个字段中的值的范围和类型是决定哪个数据类型加在这个字段上的最直接因素。

存储效率,考虑字段可能的值的范围并且根据这个范围选取一个适当的、大小合适的数据类型也是很重要的,尤其是在处理数值类型的时候。

格式和显示要求,影响字段类型选择的另一个重要因素是存储在字段内的数据的应用格式和显示要求。

数据处理要求,数据类型的选择还应该考虑数据操作和应用处理的要求,比如说某些类型更适合于加快数据操作而不是其他方面。

排序、索引和比较要求,如果想不同的标准对一列中所有的值进行排序,那么我们需要选择一种能够有效地执行这些功能并且带有最大限度的灵活性的类型。对相应字段添加索引,能够加快检索速度。比较的类型也应该使用的数据类型,需要保证使用的数据类型支持比较运算,并且相互兼容。










0 0
原创粉丝点击