MySQL字段数据类型长度
分类: 2010-09-27 16:30 105⼈阅读 (0)
⼀、MySQL 字段数据类型/长度
1、数值类型
列类型需要的存储量 TINYINT                1 字节
SMALLINT            2 个字节
MEDIUMINT          3 个字节
INT                      4 个字节
INTEGER            4 个字节
BIGINT                8 个字节
FLOAT(X)          4 如果 X < = 24 或 8 如果 25 < = X < = 53
FLOAT                4 个字节
DOUBLE              8 个字节
DOUBLE PRECISION    8 个字节
REAL                    8 个字节
DECIMAL(M,D)  M字节(D+2 , 如果M < D)
NUMERIC(M,D)  M字节(D+2 , 如果M < D)
MySQL 的数值数据类型可以⼤致划分为两个类别,⼀个是整数,另⼀个是浮点数或⼩数。许多不同的⼦类型对这些类别中的每⼀个都是可⽤的,每个⼦类型⽀持不同⼤⼩的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者⽤零填补。
请输入长度介于05之间的字符串  表列出了各种数值类型以及它们的允许范围和占⽤的内存空间。
类型⼤⼩范围(有符号)范围(⽆符号)⽤途
TINYINT  1 字节(-128,127)(0,255)⼩整数值SMALLINT  2 字节(-32 768,32 767)(0,65 535)⼤整数
值MEDIUMINT  3 字节(-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 数值类型⽤于表⽰双精度浮点数值。
  与整数⼀样,这些类型也带有附加参数:⼀个显⽰宽度指⽰器和⼀个⼩数点指⽰器。⽐如语句 FLOAT(7,3) 规定显⽰的值不会超过 7 位数字,⼩数点后⾯带有 3 位数字。
  对于⼩数点后⾯的位数超过允许范围的值,MySQL 会⾃动将它四舍五⼊为最接近它的值,再插⼊它。
  DECIMAL 数据类型⽤于精度要求⾮常⾼的计算中,这种类型允许指定数值的精度和计数⽅法作为选择参数。精度在这⾥指为这个值保存的有效数字的总个数,⽽计数⽅法表⽰⼩数点后数字的位数。⽐如语句 DECIMAL(7,3) 规定了存储的值不会超过 7 位数字,并且⼩数点后不超过 3 位。
  忽略 DECIMAL 数据类型的精度和计数⽅法修饰符将会使 MySQL 数据库把所有标识为这个数据类型的字段精度设置为 10,计算⽅法设置为 0。
  UNSIGNED(未签署) 和 ZEROFILL(零填充)修饰符也可以被 FLOAT、DOUBLE 和 DECIMAL 数据类型使⽤。并且效果与 INT 数据类型相同。
2、⽇期和时间类型
列类型需要的存储量
DATE                        3 个字节
DATETIME                8 个字节
TIMESTAMP            4 个字节
TIME                        3 个字节
YEAR                        1 字节
在处理⽇期和时间类型的值时,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 个数字表⽰的年份。DATETIME 和 TIMESTAMP 类型
  除了⽇期和时间数据类型,MySQL 还⽀持 DATEYIME 和 TIMESTAMP 这两种混合类型。它们可以把⽇期和时间作为单个的值进⾏存储。这两种类型通常⽤于⾃动存储包含当前⽇期和时间的时间戳,并可在需要执⾏⼤量数据库事务和需要建⽴⼀个调试和审查⽤途的审计跟踪的应⽤程序中发挥良好作⽤。
  如果我们对 TIMESTAMP 类型的字段没有明确赋值,或是被赋与了 null 值。MySQL 会⾃动使⽤系统当前的⽇期和时间来填充它。3、字符串类型
列类型需要的存储量
CHAR(M)                        M字节,1 <= M <= 255
VARCHAR(M)                  L+1 字节, 在此L <= M和1 <= M <= 255
TINYBLOB, TINYTEXT    L+1 字节, 在此L< 2 ^ 8
BLOB, TEXT                  L+2 字节, 在此L< 2 ^ 16
MEDIUMBLOB, MEDIUMTEXT            L+3 字节, 在此L< 2 ^ 24
LONGBLOB, LONGTEXT                  L+4 字节, 在此L< 2 ^ 32
ENUM('value1','value2',...)              1 或 2 个字节, 取决于枚举值的数⽬(最⼤值65535)
SET('value1','value2',...)                  1,2,3,4或8个字节, 取决于集合成员的数量(最多64个成员)
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 ⼦类型。⽐指定类型⽀持的最⼤范围⼤的值将被⾃动截短。
3、复合类型
  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 的⾏。
⼆、MySQL 数据表类型说明
1. MyISAM 表 MyISAM 存储格式⾃版本3.23 以来是 MySQL 中的缺省类型,它有下列特点:
■如果操作系统⾃⾝允许更⼤的⽂件,那么⽂件⽐ ISAM 存储⽅法的⼤。
■数据以低字节优先的机器独⽴格式存储。这表⽰可将表从⼀种机器拷贝到另⼀种机器,即使它们的体系结构不同也可以拷贝。
■数值索引值占的存储空间较少,因为它们是按⾼字节优先存储的。索引值在低位字节中变化很快,因此⾼位字节更容易⽐较。
■ AUTO_INCREMENT 处理⽐ ISAM 的表更好。
■减少了⼏个索引限制。例如,可对含 NULL 值的列进⾏索引,还可以对 BLOB 和 TEXT 类型的列进⾏索引。
■为了改善表的完整性检查,每个表都具有⼀个标志,在 myisamchk 对表进⾏过检查后,设置该标志。可利⽤ myisamchk - fast 跳过对⾃前次检查以来尚未被修改过表的检查,这样使此管理任务更快。表中还有⼀个指⽰表是否正常关闭的标志。如果服务器关闭不正常,或机器崩溃,此标志可⽤来检测出服务器起动时需要检查的表。
2. ISAM 表 ISAM 存储格式是 MySQL
3.23 所⽤的最旧的格式,但当前仍然可⽤。通常,相对于 ISAM 表来说,宁可使⽤ MyISAM 表,因为它们的限制较少。对 ISAM 表的⽀持随着此存储格式被 MyISAM 表格式所⽀持很有可能会逐渐消失。
3. HEAP 表 HEAP 存储格式建⽴利⽤定长⾏的内存中的表,这使表运⾏得⾮常快。在服务器停⽌时,它们将会消失。在这种意义上,这些表是临时的。但是,与⽤ CREATE TEMPORARY TABLE 所创建的临时表相⽐,HEAP 表是其他客户机可见的。HEAP 表有⼏个限制,这些限制对 MyISAM 或 ISAM 表没有,如下所⽰:
■索引仅⽤于“=”和“< = >”⽐较。
■索引列中不能有 NULL 值。
■不能使⽤ BLOB 和 TEXT 列。
■不能使⽤ AUTO_INCREMENT 列。 

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