美文网首页
MySQL 字符串数据类型

MySQL 字符串数据类型

作者: TinyDolphin | 来源:发表于2018-01-25 14:49 被阅读0次

MySQL 字符串数据类型

CHAR & VARCHAR

区别:

  • CHAR 是一种长度固定的类型;VARCHAR 是一种长度可变的类型
  • 从 CHAR 列检索出来的值,其尾部空格会被移除。对于 CHAR(M)列,如果其值的长度小于 M 个字符,那么在存入时会用空格将长度补齐。如果启用 SQL 的 PAD_CHAR_TO_FULL_LENGTH 模式,那么在检索 CHAR 列值时就可以保留尾部空格
  • 对于 VARCHAR 列,其尾部空格存储检索时都会被保留

注意:CHAR(0) 是合法的,仅一个二进制位。两种取值:NULL空串

如何选择?以下两条通用原则:

  • 如果所有值的长度固定,选用 CHAR。因为 VARCHAR 需要用额外的字节来记录值的长度。反之长度不固定,则选用 VARCHAR 节省空格占用的空间,因为 CHAR 会用空格补齐。
  • 如果使用的是 MyISAM 表,并且各个值的长度差别不大,那么选用 CAHR 更好些。因为 MyISAM 存储引擎固定长度行的处理效率高

BINARY & VARBINARY

这两种类型与 CHAR 和 VARCHAR 相似,但有以下区别:

  • CHARVARCHAR 都是用于存储字符的非二进制类型,并且都有字符集和排序规则
  • BINARY 和 VARBINARY 都是用于存储字节的二进制类型,它们没有字符集和排序规则。

对于 BINARY(M),固定长度M,会用 0x00 字节进行补齐,检索时,不会去除任何内容
对于 VARBINARY,在存储值时,不会补齐检索时,也不会去除任何内容

BLOB & TEXT

BLOB二进制大对象,一个能够存放任何内容的容器,多达 4G。存储的是二进制串,比如:压缩数据、加密数据、图像和声音。

TEXT:与 BLOB 有很多相似之处,但其存储的是非二进制串,如字符

BLOB 和 TEXT 列能否被索引,具体取决于所使用的存储引擎

  • 存储引擎 InnoDBMyISAM支持对 BLOB 和 TEXT 列进行索引,但必须指定一个前缀长度。除了 FULLTEXT 索引不会使用那个前缀长度。
  • MEMORY 引擎不支持 BLOB 和 TEXT 列。

使用注意:

  • 由于两者在长度方面的差异很大,因此在多次删除修改之后,表里容易产生大量碎片。如果使用 MyISAM 表来存储 BLOB 和 TEXT 值,那么定期运行 OPTIMIZE TABLE 命令可以减少碎片和改善系统性能
  • max_sort_length 系统变量,有必要时,可以调大。

ENUM & SET

它们只能从一个固定的字符串列表里取值。
主要区别:ENUM 列值必须包含只能包含一个值列表成员(可以为空);而 SET 列值则允许包含任意多个值列表成员。

  • ENUM单选字符串数据类型,适用于存储单选值,而 SET多选字符串数据类型,适用于存储多选值
  • MySQL 从 1 开始依次对 ENUM 列定义的成员进行顺序编号;而 SET 成员并没有按顺序编号,而被存储为二进制位值

如何字符串数据类型?

  • 这些值是要表示为字符数据还是二进制数据字符数据,选择非二进制串类型;二进制数据,选二进制串类型。
  • 比较操作需要区分大小写吗?如果需要,选非二进制串类型。因为与字符集和排序规则是相关联的。
  • 想要少占用存储空间吗?想,选用一种长度可变的类型。
  • 列的取值总是从固定的某些值里选取吗?总是,则选用 ENUMSET
  • 尾部的填充值很重要吗?如果要求数据必须原样存入和取出,不能增加和移除尾部的空格,那么应该选用 TEXT 或 VARCHAR 、BLOB 或 VARBINARY ;如果想要存储压缩数据、散列数据或加密数据时,编码方式可能会导致尾部空,需要启用 SQL 模式 PAD_CHAR_TO_FULL_LENGTH ,可以让检索出来的 CHAR 列值保留尾部空格

相关文章

  • MySQL之数据类型

    引用 详解MySQL数据类型 MySQL数据类型--字符串类 整型 数据类型字节数带符号最小值带符号最大值不带符号...

  • MYSQL复习

    mysql数据库学习 -- mysql里面的数据类型-- 数值-- 字符串-- 日期 -- 创建数据库?creat...

  • MySQL学习笔记

    MySQL MySQL常用数据类型 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型...

  • MySQL 数据表优化设计(三):CHAR 和 VARCHAR

    MySQL 支持字符串的数据类型并不多,但是却有多种变化形式。MySQL 5.0以后更是支持每一列字符串可以有自己...

  • MySQL 数据表优化设计(三):CHAR 和 VARCHAR

    MySQL 支持字符串的数据类型并不多,但是却有多种变化形式。MySQL 5.0以后更是支持每一列字符串可以有自己...

  • SQL常用数据类型

    完整数据类型参考:MySQL 数据类型 | 菜鸟教程 1.常用数据类型: 2.字符串类型 3.日期和时间类型: 注...

  • 数据库学习笔记(4)-数据类型

    MySQL 数据类型: 大致分为三类:数值、日期/时间、字符串(字符)。 数值型:

  • Mysql基础

    Mysql数据类型 字符类型 字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、T...

  • 02.创建表

    基本语法 数据类型 MySQL的数据类型包括:数值类型、时间和日期类型、字符串类型 数值类型 [图片上传失败......

  • 2019-05-17

    mysql数据类型 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。 char类型...

网友评论

      本文标题:MySQL 字符串数据类型

      本文链接:https://www.haomeiwen.com/subject/yvyvaxtx.html