MySQL 字符串数据类型

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 列值保留尾部空格
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容