mysql 193 oxcl_mysql数据类型

其中的长度以字节为单位

名称

长度

用法

TINYINT(M)

BIT,BOOL,BOOLEAN

1

如果为无符号数,可以存储从0到255的数;

否则可以存储从-128到127的数。

SMALLINT(M)

2

如果为无符号数,可以存储从0到65535的数;

否则可以存储从-32768到32767的数。

MEDIUMINT(M)

3

如果为无符号数,可以存储从0到16777215的数;否则可以存储从-8388608到8388607的数

INT(M)

INTEGER(M)

4

如果为无符号数,可以存储从0到4294967295的数,否则可以存储从-2147483648到2147483647的数。

BIGINT(M)

8

如果为无符号数,可以存储从0到18446744073709551615的数,否则可以存储从-9223372036854775808到9223372036854775807的数。

FLOAT(precision)

4或8

这里的precision是可以直达53的整数。如果precision<=24则转换为FLOAT,如果precision>24并且precision<=53则转换为DOUBLE。

FLOAT(M,D)

4

单精度浮点数。

DOUBLE(M,D),

DOUBLE PRECISION,

REAL

8

双精度浮点。

DECIMAL(M,D),

DEC,NUMERIC,FIXED

M+1或M+2

未打包的浮点数。

DATE

3

以YYYY-MM-DD的格式显示。

DATETIME

HH:MM:SS

8

以YYYY-MM-DD的格式显示。

TIMESTAMP

4

以YYYY-MM-DD的格式显示。

TIME

3

以HH:MM:SS的格式显示。

YEAR

1

以YYYY的格式显示。

CHAR(M)

M

定长字符串。

VARCHAR(M)

最大M

变长字符串。M<=255.

TINYBLOB,

TINYTEXT

最大255

TINYBLOB为大小写敏感,而TINYTEXT不是大小写敏感的。

BLOB,

TEXT

最大64K

BLOB为大小敏感的,而TEXT不是大小写敏感的。

MEDIUMBLOB,

MEDIUMTEXT

最大16M

MEDIUMBLOB为大小写敏感的,而MEDIUMTEXT不是大小敏感的。

LONGBLOB,

LONGTEXT

最大4G

LONGBLOB为大小敏感的,而LONGTEXT不是大小敏感的。

ENUM(VALUE1,….)

1或2

最大可达65535个不同的值。

SET(VALUE1,….)

可达8

最大可达64个不同的值。

1. CHAR和VARCHAR类型

在检索的时候,CHAR 列删除了尾部的空格,而VARCHAR则保留这些空格。例,如下:

19813254_1.jpg

2.  BINARY和VARBINARY类似于CHAR和VARCHAR,不同的是它们包含二进制字符串而不包含非二进制字符串。例子如下:

19813254_2.jpg

可以发现,当保存BINARY值时,在值的最后通过填充“ox00”(零字节)以达到指定的字段定义长度。

3.ENUM中文名称叫枚举类型,它的值范围需要在创建表时通过枚举方式显示指定,对1~255个成员的枚举需要1个字节存储;对于255~65535个成员,需要2个字节存储。最多允许有65535个成员。

ENUM 类型因为只允许在集合中取得一个值,有点类似于单选项。在处理相互排拆的数据时容易让人理解,比如人类的性别。ENUM 类型字段可以从集合中取得一个值或使用 null 值,除此之外的输入将会使 MySQL 在这个字段中插入一个空字符串。另外如果插入值的大小写与集合中值的大小写不匹配,MySQL 会自动使用插入值的大小写转换成与集合中大小写一致的值。

ENUM 类型在系统内部可以存储为数字,并且从 1 开始用数字做索引。一个 ENUM 类型最多可以包含 65536 个元素,其中一个元素被 MySQL 保留,用来存储错误信息,这个错误值用索引 0 或者一个空字符串表示。

MySQL 认为 ENUM 类型集合中出现的值是合法输入,除此之外其它任何输入都将失败。这说明通过搜索包含空字符串或对应数字索引为 0 的行就可以很容易地找到错误记录的位置。

举例如下:

19813254_3.jpg

从上面的例子中可以看出ENUM类型是忽略大小的,对’M’ , ‘f’在存储的时候将它们都转成了大写,还可以看出对于插入不在ENUM指定范围内的值时,并没有返回警告,而是插入了enum(‘M’ , ‘F’)的第一值‘M‘,这点要特别注意。

另外,ENUM类型只允许从值集合中选取单个值,而不能一次取多个值。

4.  SET类型

Set和ENUM类型非常类似,也是一个字符串对象,里面可以包含0~64个成员。根据成员的不同,存储上也有所不同。

1~8成员的集合,占1个字节

9~16成员的集合,占2个字节

17~24成员的集合,占3个字节

25~32成员的集合,占4个字节

33~64成员的集合,占5个字节

SET 类型与 ENUM 类型相似但不相同。Set和ENUM除了存储之外,最主要的区别在于set类型一次可以选取多个成员,而ENUM则只能选择一个。

SET 类型可以从预定义的集合中取得任意数量的值。并且与 ENUM 类型相同的是任何试图在 SET 类型字段中插入非预定义的值都会使 MySQL 插入一个空字符串。如果插入一个即有合法的元素又有非法的元素的记录,MySQL 将会保留合法的元素,除去非法的元素。

一个 SET 类型最多可以包含 64 项元素。在 SET 元素中值被存储为一个分离的“位”序列,这些“位”表示与它相对应的元素。“位”是创建有序元素集合的一种简单而有效的方式。并且它还去除了重复的元素,所以 SET 类型中不可能包含两个相同的元素。

希望从 SET 类型字段中找出非法的记录只需查找包含空字符串或二进制值为 0 的行。

举例如下:

19813254_4.jpg

Set类型可以从允许值集合中选择任意1个或多个元素进行组合,所以对于输入的值只要是在允许值的组合范围内,都可以正确的注入到set类型的列中。对于超出允许值范围的值例如(’a,v’)将不允许注入到上面例子中设置的set类型列中,而对于(’a,d,a’)这样包含重复成员的集合将只取一次,写入后的结果为“a,d”5.   TEXT 和 BLOB 类型

对于字段长度要求超过 255 个的情况下,MySQL 提供了 TEXT 和 BLOB 两种类型。根据存储数据的大小,它们都有不同的子类型。这些大型的数据用于存储文本块或图像、声音文件等二进制数据类型。

TEXT 和 BLOB 类型在分类和比较上存在区别。BLOB 类型区分大小写,而 TEXT 不区分大小写。大小修饰符不用于各种 BLOB 和 TEXT 子类型。比指定类型支持的最大范围大的值将被自动截短。

6.    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 个数字表示的年份。

7   DATEYIME 和 TIMESTAMP 类型

除了日期和时间数据类型,MySQL 还支持 DATEYIME 和 TIMESTAMP 这两种混合类型。它们可以把日期和时间作为单个的值进行存储。这两种类型通常用于自动存储包含当前日期和时间的时间戳,并可在需要执行大量数据库事务和需要建立一个调试和审查用途的审计跟踪的应用程序中发挥良好作用。

如果我们对 TIMESTAMP 类型的字段没有明确赋值,或是被赋与了 null 值。MySQL 会自动使用系统当前的日期和时间来填充它。

8.   复合类型

MySQL 还支持两种复合数据类型 ENUM 和 SET,它们扩展了 SQL 规范。虽然这些类型在技术上是字符串类型,但是可以被视为不同的数据类型。一个 ENUM 类型只允许从一个集合中取得一个值;而 SET 类型允许从一个集合中取得任意多个值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值