MySQL_数据库数据类型(datatype)介绍
MySQL_数据库数据类型(data type)介绍 mysql数据库的数据类型(data type)分以下⼏种:数值类型,字符串类型
⼀、数值类型
MySQL 的数值类型可以⼤致划分为两个类别,⼀个是整数,另⼀个是浮点数或⼩数。许多不同的⼦类型对这些类别中的每⼀个都是可⽤的,每个⼦类型⽀持不同⼤⼩的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者⽤零填补。
下表列出了各种数值类型以及它们的允许范围和占⽤的内存空间。
类型字节⼤⼩范围(有符号)范围(⽆符号)⽤途
TINYINT  1 字节最⼩:-128
最⼤:127
最⼩:0
最⼤:255
⼩整数值
SMALLINT  2 字节最⼩:-32768
最⼤:32767
最⼩:0
最⼤:65535
短整数值
MEDIUMINT  3 字节最⼩:-8388608
最⼤:8388607
linux简单教程学习
最⼩:0
最⼤:16777215
安装sql server2008⼤整数值
INT或INTEGER 4 字节
最⼩:-2147483648
最⼤:2147483647
最⼩:0
最⼤:4294967295
⼤整数值
BIGINT8 字节最⼩:-
9233372036854775808
最⼤:
9223372036854775807
最⼩:0
最⼤:
linux打开nginx配置文件18446744073709551615
极⼤整数
FLOAT  4 字节单精度浮点数值
DOUBLE8 字节双精度浮点数值
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 位。
wps启用宏vba免费下载忽略 DECIMAL 数据类型的精度和计数⽅法修饰符将会使 MySQL 数据库把所有标识为这个数据类型的字段精度设置为 10,计算⽅法设置为 0。
UNSIGNED 和 ZEROFILL 修饰符也可以被 FLOAT、DOUBLE 和 DECIMAL 数据类型使⽤。并且效果与 INT 数据类型相同。
⼆、字符串类型
MySQL 提供了 8 个基本的字符串类型,可以存储的范围从简单的⼀个字符到巨⼤的⽂本块或⼆进制字符串数据。
类型⼤⼩⽤途
CHAR0-255字节定长字符串
VARCHAR0-255字节变长字符串
TINYBLOB0-255字节不超过 255 个字符的⼆进制字符串
TINYTEXT0-255字节短⽂本字符串
BLOB0-65535字节⼆进制形式的长⽂本数据
TEXT0-65535字节长⽂本数据
MEDIUMBLOB0-16777215字节⼆进制形式的中等长度⽂本数据
MEDIUMTEXT0-16777215字节中等长度⽂本数据
LOGNGBLOB0-4294967295字节⼆进制形式的极⼤⽂本数据
LONGTEXT0-4294967295字节极⼤⽂本数据
CHAR 和 VARCHAR 类型
CHAR 类型⽤于定长字符串,并且必须在圆括号内⽤⼀个⼤⼩修饰符来定义。这个⼤⼩修饰符的范围从 0-255。⽐指定长度⼤的值将被截短,⽽⽐指定长度⼩的值将会⽤空格作填补。
CHAR 类型可以使⽤ BINARY 修饰符。当⽤于⽐较运算时,这个修饰符使 CHAR 以⼆进制⽅式参于运算,⽽不是以传统的区分⼤⼩写的⽅式。
CHAR 类型的⼀个变体是 VARCHAR 类型。它是⼀种可变长度的字符串类型,并且也必须带有⼀个范围在 0-255 之间的指⽰器。CHAR 和 VARCHGAR 不同之处在于 MuSQL 数据库处理这个指⽰器的⽅式:CHAR 把这个⼤⼩视为值的⼤⼩,不长度不⾜的情况下就⽤空格补⾜。⽽ VARCHAR 类型把它视为最⼤值并且只使⽤存储字符串实际需要的长度(增加⼀个额外字节来存储字符串本⾝的长度)来存储值。所以短于指⽰器长度的 VARCHAR 类型不会被空格填补,但长于指⽰器的值仍然会被截短。
因为 VARCHAR 类型可以根据实际内容动态改变存储值的长度,所以在不能确定字段需要多少字符时使⽤ VARCHAR 类型可以⼤⼤地节约磁盘空间、提⾼存储效率。
VARCHAR 类型在使⽤ BINARY 修饰符时与 CHAR 类型完全相同。
下⾯的表显⽰了将各种字符串值保存到CHAR(4)和VARCHAR(4)列后的结果,说明了CHAR和VARCH
AR之间的差别:
值CHAR(4)存储需求VARCHAR(4)存储需求
''' '4个字节''1个字节
'ab ''ab '4个字节'ab '3个字节
'abcd''abcd'4个字节'abcd'4个字节
'abcdefgh''abcd'4个字节'abcd'4个字节
请注意上表中最后⼀⾏的值只适⽤不使⽤严格模式时,如果MySQL运⾏在严格模式,超过列长度不的值不保存,并且会出现错误。
错误信息如下:
ATE TABLE vc (v VARCHAR(4), c CHAR(4));
INSERT INTO vc VALUES ('abcde', 'abcdef');
1406 - Data too long for column 'v' at row 1
TEXT 和 BLOB 类型mysql语句分类
对于字段长度要求超过 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:59HH: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 类型在系统内部可以存储为数字,并且从 1 开始⽤数字做索引。⼀个 ENUM 类型最多可以包含 65536 个元素,其中⼀个元素被MySQL 保留,⽤来存储错误信息,这个错误值⽤索引 0 或者⼀个空字符串表⽰。
MySQL 认为 ENUM 类型集合中出现的值是合法输⼊,除此之外其它任何输⼊都将失败。这说明通过搜索包含空字符串或对应数字索引为0 的⾏就可以很容易地到错误记录的位置。
SET 类型
⼀个 SET 类型最多可以包含 64 项元素。在 SET 元素中值被存储为⼀个分离的“位”序列,这些“位”表⽰与它相对应的元素。“位”是创建有序元素集合的⼀种简单⽽有效的⽅式。并且它还去除了重复的元素,所以 SET 类型中不可能包含两个相同的元素。
希望从 SET 类型字段中出⾮法的记录只需查包含空字符串或⼆进制值为 0 的⾏。

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