mysql的float取值范围_MYSQL中⽀持的数据类型及取值范围下表列出了各种数值类型以及它们的允许范围和占⽤的内存空间。
类型
⼤⼩
范围(有符号)
范围(⽆符号)
⽤途
TINYINT
1字节
-128~127
0~255
⼩整数值
SMALLINT
2字节
-32768~32767
0~65535
⼤整数值
MEDIUMINT
3字节
-8388608~8388607
0~16777215
⼤整数值
INT或INTEGER
4字节
-2147483648~2147483647
0~4294967295
⼤整数值
BIGINT
8字节
-9223372036854775808~9223372036854775807
0~18446744073709551615
极⼤整数值
FLOAT
4字节
-
3.402823466E+38~1.175494351E-38,0,1.175494351E-38~ 3.402823466E+38
0,1.175494351E-38~3.402823466E+38
单精度
浮点数值
DOUBLE
8字节
-1.7976931348623157E+308~
2.2250738585072014E-308,
0,2.2250738585072014E-308
~1.7976931348623157E+308
0,2.2250738585072014E-308~1.7976931348623157E+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 数据类型相同。
字符串类型MySQL 提供了 8 个基本的字符串类型,可以存储的范围从简单的⼀个字符到巨⼤的⽂本块或⼆进制字符串数据。
类型
⼤⼩
⽤途
CHAR
0~255字节
定长字符串
VARCHAR
0~255字节
变长字符串
TINYBLOB
0~255字节
不超过255个字符的⼆进制字符串
TINYTEXT
0~255字节
短⽂本字符串
BLOB
0~65535字节
⼆进制形式的长⽂本数据
TEXT
0~65535字节
长⽂本数据
MEDIUMBLOB
0~16777215字节
⼆进制形式的中等长度⽂本数据
MEDIUMTEXT
0~16777215字节
中等长度⽂本数据
LOGNGBLOB
0~4294967295字节
⼆进制形式的极⼤⽂本数据
LONGTEXT
0~4294967295字节
极⼤⽂本数据
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 带有内置功能可以把多样化的输⼊格式变为⼀个标准格式。
类型
⼤⼩(字节)
范围
格式
⽤途
DATE
3
mysql创建表数据类型1000-01-01~9999-12-31
YYYY-MM-DD
⽇期值
TIME
3
-838:59:59~838:59:59
HH:MM:SS
时间值或持续时间
YEAR
1
1901/2155
YYYY
年份值
DATETIME
8
1000-01-01 00:00:00~9999-12-31 23:59:59
YYYY-MM-DD HH:MM:SS
⽇期和时间值
TIMESTAMP
8
1970-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 或者⼀个空字符串表⽰。

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