MySQL数据类型全解析
数据类型:定义列中可以存储什么数据以及该数据实际怎样存储的基本规则。
数据类型用于以下目的:
1、允许限制可存储在列中的数据。如:数值数据类型列只能接受数值。
2、允许在内部更有效地存储数据。如:用比文本串更简洁的格式存储数值和日期时间值。
3、允许变换排序顺序。如:数据都作为串处理,则1位于10前,10位于2前(串以字典顺序排序,从左边开始比较,一次一个字符);作为数值数据类型,数值才能正确排序。
一、串数据类型
最常用的数据类型,存储串,如名字、地址、电话号码等。
两种基本的串类型:定长串和变长串。
定长串:接受长度固定的字符串,其长度是在创建表时指定的。定长列不允许多于指定的字符数目,它们分配的存储空间与指定的一样多。如:char。
变长串:存储可变长度的文本。有些变长数据类型具有最大的定长,有些则是完全变长的,不管是哪种,只有指定的数据会得到保存(额外的数据不保存),如:text。
ps:mysql处理定长列远比处理变长列快得多。且mysql不允许对变长列(或一个列的可变部分)进行索引。
数据类型说明:
char:1~255个字符的定长串。长度必须在创建时指定,否则mysql假定为char(1)。
enum:接受最多64k个串组成的一个预定义集合的某个串。
longtext:与text相同,但最大长度为4gb。
mediumtext:与text相同,但最大长度为16 k。
set:接受最多64个串组成的一个预定义集合的零个或多个串。
text:最大长度为64 k的变长文本。
tinytext:与text相同,但最大长度为255字节。
varchar:长度可变,最多不超过255字节。如创建时指定为varchar(n),则可存储0到n个字符的变长串(其中n≤255)。
ps:
1、引号:使用何种形式的串数据类型,串值都必须括在引号内(通常使用单引号)。
2、须遵守的基本规则:如果数值是计算(求和、平均等)中使用的数值,则存储在数值数据类型列中。如果数值作为字符串使用,则保存在串数据类型列中。如:在数值字段中存储邮政编码01234,保存的是数值1234,丢失了一位数字。
二、数值数据类型
存储数值。mysql支持多种数值数据类型,每种存储的数值具有不同的取值范围。
支持的取值范围越大,所需存储空间越多。此外,有的数值数据类型支持使用十进制小数点(和小数),而有的则只支持整数。表d-2列出了常用的mysql数值数据类型。
ps:
1、所有数值数据类型(除bit和boolean外)都可以有符号或无符号。有符号数值列可以存储正或负的数值,无符号数值列只能存储正数。
2、默认情况为有符号,若不需要存储负值,可以使用unsigned,这样做将允许你存储两倍大小的值。
3、与串不同,数值不应该在引号内。
4、mysql中没有专门存储货币的数据类型,一般情况下使用decimal(8, 2)。
数据类型说明:
bit:位字段,1~64位。在mysql 5之前,bit在功能上等价于tinyint。
bigint:整数值,支持-9223372036854775808~9223372036854775807。如果是unsigned,为0~18446744073709551615的数。
boolean(或bool):布尔标志,为0或者为1,主要用于开/关(on/off)标志。
decimal(或dec):精度可变的浮点值。
double:双精度浮点值
float:单精度浮点值
int(或integer):整数值,支持-2147483648~2147483647,unsigned同上。
mediumint:整数值,支持-8388608~8388607,unsigned同上。
real:4字节的浮点值。
smallint:整数值,支持-32768~32767,unsigned同上。
tinyint:整数值,支持-128~127,unsigned同上。
三、日期和时间数据类型
数据类型说明:
date:表示1000-01-01~9999-12-31的日期,格式为yyyy-mm-dd。
datetime:date和time的组合。
timestamp:功能和datetime相同,但范围较小。
time:格式为hh:mm:ss。
year:2位数字表示,范围是70~69(1970~2069);4位数字表示,范围是1901~2155
四、二进制数据类型
可存储任何数据(甚至包括二进制信息),如图像、多媒体、字处理文档等。
数据类型说明:
blob:blob最大长度为64kb。
mediumblob:blob最大长度为16 mb。
longblob:blob最大长度为4gb。
tinyblob:blob最大长度为255字节。
以上就是mysql数据类型全解析的详细内容,更多关于mysql数据类型的资料请关注其它相关文章!
上一篇: 云计算会给微软带来200亿美元营收吗?
下一篇: 扫地机器人成新蓝海 “专利大战”率先打响