MySQL数据类型详解
1、整型
MySQL数据类型含义(有符号)
tinyint(m)1个字节范围(-128~127)
smallint(m)2个字节范围(-32768~32767)
mediumint(m)3个字节范围(-8388608~8388607)
int(m)4个字节范围(-2147483648~2147483647)
bigint(m)8个字节范围(+-9.22*10的18次⽅)
取值范围如果加了unsigned,则最⼤值翻倍,如tinyint unsigned的取值范围为(0~256)。
int(m)⾥的m是表⽰SELECT查询结果集中的显⽰宽度,并不影响实际的取值范围,没有影响到显⽰的宽度,不知道这个m有什么⽤。
2、浮点型(float和double)
MySQL数据类型含义
float(m,d)单精度浮点型 8位精度(4字节) m总个数,d⼩数位
double(m,d)双精度浮点型 16位精度(8字节) m总个数,d⼩数位
设⼀个字段定义为float(5,3),如果插⼊⼀个数123.45678,实际数据库⾥存的是123.457,但总个数还以实际为准,即6位。3、定点数
浮点型在数据库中存放的是近似值,⽽定点类型在数据库中存放的是精确值。
decimal(m,d) 参数m<65 是总个数,d<30且 d<m 是⼩数位。
4、字符串(char,varchar,_text)
MySQL数据类型含义
char(n)固定长度,最多255个字符
varchar(n)固定长度,最多65535个字符
tinytext可变长度,最多255个字符
text可变长度,最多65535个字符
mediumtext可变长度,最多2的24次⽅-1个字符
longtext可变长度,最多2的32次⽅-1个字符
char和varchar:
1.char(n) 若存⼊字符数⼩于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空
格,varchar不限于此。
2.char(n) 固定长度,char(4)不管是存⼊⼏个字符,都将占⽤4个字节,varchar是存⼊的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存⼊3个字符将占⽤4个字节。
3.char类型的字符串检索速度要⽐varchar类型的快。
varchar和text:
1.varchar可指定n,text不能指定,内部存储varchar是存⼊的实际字符数+1个字节(n<=255)或2个字
节(n>255),text是实际字符数+2个字节。
<类型不能有默认值。
3.varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作⽤。
5.⼆进制数据(_Blob)
1._BLOB和_text存储⽅式不同,_TEXT以⽂本⽅式存储,英⽂存储区分⼤⼩写,⽽_Blob是以⼆进制⽅式存储,不分⼤⼩写。
2._BLOB存储的数据只能整体读出。
3._TEXT可以指定字符集,_BLO不⽤指定字符集。
6.⽇期时间类型
MySQL数据类型含义
date⽇期 '2008-12-2'
time时间 '12:25:36'
datetime⽇期时间 '2008-12-2 22:06:44'
timestamp⾃动存储记录修改时间
若定义⼀个字段为timestamp,这个字段⾥的时间数据会随其他字段修改的时候⾃动刷新,所以这个数据类型的字段可以存放这条记录最后被修改的时间。
数据类型的属性
MySQL关键字含义
NULL数据列可包含NULL值
NOT NULL数据列不允许包含NULL值
DEFAULT默认值
PRIMARY KEY主键
AUTO_INCREMENT⾃动递增,适⽤于整数类型
UNSIGNED⽆符号
CHARACTER SET
name指定⼀个字符集
表列出了各种数值类型以及它们的允许范围和占⽤的内存空间。
类型⼤⼩范围(有符号)范围(⽆符号)⽤途
TINYINT  1 字节(-128,127)(0,255)⼩整数值SMALLINT  2 字节(-32 768,32 767)(0,65 535)⼤整数值MEDIUMINT3 字节(-8 388 608,8 388 607)(0,16 777 215)⼤整数值
INT或
INTEGER
4 字节(-2 147 483 648,2 147 483 647)(0,4 294 967 295)⼤整数值
BIGINT8 字节(-9 233 372 036 854 775 808,9
223 372 036 854 775 807)
(0,18 446 744 073 709 551 615)极⼤整数值
FLOAT  4 字节(-3.402 823 466 E+38,1.175 494
351 E-38),0,(1.175 494 351 E-
38,3.402 823 466 351 E+38)
0,(1.175 494 351 E-38,3.402
823 466 E+38)单精度浮点数值
DOUBLE8 字节(1.797 693 134 862 315 7
E+308,2.225 073 858 507 201 4
E-308),0,(2.225 073 858 507
201 4 E-308,1.797 693 134 862
315 7 E+308)
0,(2.225 073 858 507 201 4 E-
308,1.797 693 134 862 315 7
E+308)
双精度浮点数值
DECIMAL 对DECIMAL(M,D)
,如果M>D,为
M+2否则为D+2
依赖于M和D的值依赖于M和D的值⼩数值
INT 类型
  在 MySQL 中⽀持的 5 个主要整数类型是 TINYINT,SMALLINT,MEDIUMINT,INT 和 BIGINT。这些类型在很⼤程度
上是相同的,只有它们存储的值的⼤⼩是不相同的。
  MySQL 以⼀个可选的显⽰宽度指⽰器的形式对 SQL 标准进⾏扩展,这样当从数据库检索⼀个值时,可以把这个值加长到指定的长度。例如,指定⼀个字段的类型为 INT(6),就可以保证所包含数字少于 6 个的值从数据库中检索出来时能够⾃动地⽤空格填充。需要注意的是,使⽤⼀个宽度指⽰器不会影响字段的⼤⼩和它可以存储的值的范围。
  万⼀我们需要对⼀个字段存储⼀个超出许可范围的数字,MySQL 会根据允许范围最接近它的⼀端截短后再进⾏存储。还有⼀个⽐较特别的地⽅是,MySQL 会在不合规定的值插⼊表前⾃动修改为 0。
  UNSIGNED 修饰符规定字段只保存正值。因为不需要保存数字的正、负符号,可以在储时节约⼀个“位”的空间。从⽽增⼤这个字段可以存储的值的范围。
  ZEROFILL 修饰符规定 0(不是空格)可以⽤来真补输出的值。使⽤这个修饰符可以阻⽌ MySQL 数据库存储负值。
FLOAT、DOUBLE 和 DECIMAL 类型
  MySQL ⽀持的三个浮点类型是 FLOAT、DOUBLE 和 DECIMAL 类型。FLOAT 数值类型⽤于表⽰单精度浮点数值,⽽DOUBLE 数值类型⽤于表⽰双精度浮点数值。varchar2最大长度
  与整数⼀样,这些类型也带有附加参数:⼀个显⽰宽度指⽰器和⼀个⼩数点指⽰器。⽐如语句 FLOAT(
7,3) 规定显⽰的值不会超过 7 位数字,⼩数点后⾯带有 3 位数字。
  对于⼩数点后⾯的位数超过允许范围的值,MySQL 会⾃动将它四舍五⼊为最接近它的值,再插⼊它。
  DECIMAL 数据类型⽤于精度要求⾮常⾼的计算中,这种类型允许指定数值的精度和计数⽅法作为选择参数。精度在这⾥指为这个值保存的有效数字的总个数,⽽计数⽅法表⽰⼩数点后数字的位数。⽐如语句 DECIMAL(7,3) 规定了存储的值不会超过 7 位数字,并且⼩数点后不超过 3 位。
  忽略 DECIMAL 数据类型的精度和计数⽅法修饰符将会使 MySQL 数据库把所有标识为这个数据类型的字段精度设置为10,计算⽅法设置为 0。
  UNSIGNED 和 ZEROFILL 修饰符也可以被 FLOAT、DOUBLE 和 DECIMAL 数据类型使⽤。并且效果与 INT 数据类型相同。
字符串类型
  MySQL 提供了 8 个基本的字符串类型,可以存储的范围从简单的⼀个字符到巨⼤的⽂本块或⼆进制字符串数据。
类型⼤⼩⽤途
CHAR0-255字节定长字符串
VARCHAR0-255字节变长字符串
TINYBLOB0-255字节不超过 255 个字符的⼆进制字符串
TINYTEXT0-255字节短⽂本字符串
BLOB0-65 535字节⼆进制形式的长⽂本数据
TEXT0-65 535字节长⽂本数据
MEDIUMBLOB0-16 777 215字节⼆进制形式的中等长度⽂本数据
MEDIUMTEXT0-16 777 215字节中等长度⽂本数据
LOGNGBLOB0-4 294 967 295字节⼆进制形式的极⼤⽂本数据
LONGTEXT0-4 294 967 295字节极⼤⽂本数据
CHAR 和 VARCHAR 类型
  CHAR 类型⽤于定长字符串,并且必须在圆括号内⽤⼀个⼤⼩修饰符来定义。这个⼤⼩修饰符的范围从 0-255。⽐指定长度⼤的值将被截短,⽽⽐指定长度⼩的值将会⽤空格作填补。
  CHAR 类型可以使⽤ BINARY 修饰符。当⽤于⽐较运算时,这个修饰符使 CHAR 以⼆进制⽅式参于运算,⽽不是以传统的区分⼤⼩写的⽅式。
  CHAR 类型的⼀个变体是 VARCHAR 类型。它是⼀种可变长度的字符串类型,并且也必须带有⼀个范围在 0-255 之间的指⽰器。CHAR 和 VARCHGAR 不同之处在于 MuSQL 数据库处理这个指⽰器的⽅式:CHAR 把这个⼤⼩视为值的⼤⼩,不长度不⾜的情况下就⽤空格补⾜。⽽ VARCHAR 类型把它视为最⼤值并且只使⽤存储字符串实际需要的长度(增加⼀个额外字节来存储字符串本⾝的长度)来存储值。所以短于指⽰器长度的 VARCHAR 类型不会被空格填补,但长于指⽰器的值仍然
会被截短。
  因为 VARCHAR 类型可以根据实际内容动态改变存储值的长度,所以在不能确定字段需要多少字符时使⽤ VARCHAR 类型可以⼤⼤地节约磁盘空间、提⾼存储效率。
  VARCHAR 类型在使⽤ BINARY 修饰符时与 CHAR 类型完全相同。
TEXT 和 BLOB 类型
  对于字段长度要求超过 255 个的情况下,MySQL 提供了 TEXT 和 BLOB 两种类型。根据存储数据的⼤⼩,它们都有不同的⼦类型。这些⼤型的数据⽤于存储⽂本块或图像、声⾳⽂件等⼆进制数据类型。
  TEXT 和 BLOB 类型在分类和⽐较上存在区别。BLOB 类型区分⼤⼩写,⽽ TEXT 不区分⼤⼩写。⼤⼩修饰符不⽤于各种 BLOB 和 TEXT ⼦类型。⽐指定类型⽀持的最⼤范围⼤的值将被⾃动截短。
⽇期和时间类型
  在处理⽇期和时间类型的值时,MySQL 带有 5 个不同的数据类型可供选择。它们可以被分成简单的⽇期、时间类型,和混合⽇期、时间类型。根据要求的精度,⼦类型在每个分类型中都可以使⽤,并且 MySQL 带有内置功能可以把多样化的输⼊格式变为⼀个标准格式。
类型⼤⼩ (字节)范围格式⽤途
DATE31000-01-01/9999-12-31YYYY-MM-DD⽇期值
TIME3'-838:59:59'/'838:59:59'HH:MM:SS时间值或持续时间YEAR11901/2155YYYY年份值
DATETIME81000-01-01 00:00:00/9999-12-31 23:59:59YYYY-MM-DD
HH:MM:SS混合⽇期和时间值
TIMESTAMP81970-01-01 00:00:00/2037 年某时YYYYMMDD HHMMSS混合⽇期和时间值,时
间戳
DATE、TIME 和 TEAR 类型
  MySQL ⽤ DATE 和 TEAR 类型存储简单的⽇期值,使⽤ TIME 类型存储时间值。这些类型可以描述为字符串或不带分隔符的整数序列。如果描述为字符串,DATE 类型的值应该使⽤连字号作为分隔符分开,⽽ TIME 类型的值应该使⽤冒号作为分隔符分开。
  需要注意的是,没有冒号分隔符的 TIME 类型值,将会被 MySQL 理解为持续的时间,⽽不是时间戳。
  MySQL 还对⽇期的年份中的两个数字的值,或是 SQL 语句中为 TEAR 类型输⼊的两个数字进⾏最⼤限度的通译。因为所有 TEAR 类型的值必须⽤ 4 个数字存储。MySQL 试图将 2 个数字的年份转换为 4 个数字的值。把在 00-69 范围内的值转换到 2000-2069 范围内。把 70-99 范围内的值转换到 1970-1979 之内。如果 MySQL ⾃动转换后的值并不符合我们的需要,请输⼊ 4 个数字表⽰的年份。
DATEYIME 和 TIMESTAMP 类型
  除了⽇期和时间数据类型,MySQL 还⽀持 DATEYIME 和 TIMESTAMP 这两种混合类型。它们可以把
⽇期和时间作为单个的值进⾏存储。这两种类型通常⽤于⾃动存储包含当前⽇期和时间的时间戳,并可在需要执⾏⼤量数据库事务和需要建⽴⼀个调试和审查⽤途的审计跟踪的应⽤程序中发挥良好作⽤。
  如果我们对 TIMESTAMP 类型的字段没有明确赋值,或是被赋与了 null 值。MySQL 会⾃动使⽤系统当前的⽇期和时间来填充它。
复合类型
  MySQL 还⽀持两种复合数据类型 ENUM 和 SET,它们扩展了 SQL 规范。虽然这些类型在技术上是字符串类型,但是可以被视为不同的数据类型。⼀个 ENUM 类型只允许从⼀个集合中取得⼀个值;⽽ SET 类型允许从⼀个集合中取得任意多个值。
ENUM 类型
  ENUM 类型因为只允许在集合中取得⼀个值,有点类似于单选项。在处理相互排拆的数据时容易让⼈理解,⽐如⼈类的性别。ENUM 类型字段可以从集合中取得⼀个值或使⽤ null 值,除此之外的输⼊将会使 MySQL 在这个字段中插⼊⼀个空字符串。另外如果插⼊值的⼤⼩写与集合中值的⼤⼩写不匹配,MySQL 会⾃动使⽤插⼊值的⼤⼩写转换成与集合中⼤⼩写⼀致的值。
  ENUM 类型在系统内部可以存储为数字,并且从 1 开始⽤数字做索引。⼀个 ENUM 类型最多可以包含
65536 个元素,其中⼀个元素被 MySQL 保留,⽤来存储错误信息,这个错误值⽤索引 0 或者⼀个空字符串表⽰。
  MySQL 认为 ENUM 类型集合中出现的值是合法输⼊,除此之外其它任何输⼊都将失败。这说明通过搜索包含空字符串或对应数字索引为 0 的⾏就可以很容易地到错误记录的位置。
SET 类型
  SET 类型与 ENUM 类型相似但不相同。SET 类型可以从预定义的集合中取得任意数量的值。并且与 ENUM 类型相同的是任何试图在 SET 类型字段中插⼊⾮预定义的值都会使 MySQL 插⼊⼀个空字符串。如果插⼊⼀个即有合法的元素⼜有⾮法的元素的记录,MySQL 将会保留合法的元素,除去⾮法的元素。
  ⼀个 SET 类型最多可以包含 64 项元素。在 SET 元素中值被存储为⼀个分离的“位”序列,这些“位”表⽰与它相对应的元素。“位”是创建有序元素集合的⼀种简单⽽有效的⽅式。并且它还去除了重复的元素,所以 SET 类型中不可能包含两个相同的元素。
  希望从 SET 类型字段中出⾮法的记录只需查包含空字符串或⼆进制值为 0 的⾏。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。