【MySQL】轻松学习 列的类型定义(三)CHAR与VARCHAR和TEXT类型

2023-10-07 22:20

本文主要是介绍【MySQL】轻松学习 列的类型定义(三)CHAR与VARCHAR和TEXT类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

    🍀🍀🍀

    一、CHAR和VARCHAR

    二、TEXT类型


一、CHAR和VARCHAR

    CHAR类型和VARCHAR类型都在创建表时指定了最大长度,其基本形式如下:

    字符串类型(M)


    其中,“字符串类型”参数指定了数据类型为CHAR类型还是VARCHAR类型;M参数指定了该字符串的最大长度为M。例如,CHAR(4)就是数据类型为CHAR类型,其最大长度为4。

    1、CHAR类型的长度是固定的,在创建表时就指定了。其长度可以是0~255的任意值。例如,CHAR(100)就是指定CHAR类型的长度为100。CHAR 存储值时,它们会用空格右填充到指定的长度

    2、VARCHAR类型的长度是可变的,在创建表时指定了最大长度。定义时,其最大值可以取0~65535之间的任意值。指定VARCHAR类型的最大值以后,其长度可以在0到最大长度之间。例如,VARCHAR(100)的最大长度是100,但是不是每条记录都要占用100个字节,而是在这个最大值范围内使用多少就分配多少。VARCHAR类型实际占用的空间为字符串的实际长度加1或2(存放这个自负床的长度),这样即可有效节约系统的空间。

(char在存储时,右边会以空格填充,在检索时,char会将右边空格删除)

create table char_example(e_char char(5), v_char varchar(5));
insert into char_example values('12345','12345'); 


    #char类型会屏蔽后面隐藏的空格,varchar 不会

 insert into char_example values('1 2  ','1 2  ');   

     这样看起来好像并没有什么差别,我们将select结果与“()”连接起来;(使用concat()函数);

select concat('(',e_char, ')'), concat('(',v_char, ')')  from char_example ; 

     varchar会根据输入字符串长度存储,而char则会将空格屏蔽掉(类似于C语言,varchar存储string.length,而char类似于字符数组只存储到'\0'符)


    当插入记录过长时则会报错

mysql>  insert into char_example values('12345','1234567');
ERROR 1406 (22001): Data too long for column 'v_char' at row 1

     但是有一种情况,当插入空格数多于指定长度时;

     这里空格+字符均有7个长度;

insert into char_example values('1 2   ','1 2   ');

 


char与varchar的总结

  1. char一定会使用指定的空间,varchar是根据数据来定空间
  2. char的数据查询效率比varchar高:varchar是需要通过后面的记录数来计算
  3. 如果确定数据一定是占指定长度,那么使用char类型;
  4. 如果不确定数据到底有多少,那么使用varchar类型;
  5. 如果数据长度超过255个字符而在65535之内,直接使用varchar
  6. 如果字符串尾部要保留空格,必须选择varchar
  7. char在存储的时候会将右侧空格进行剔除,保留左侧空格。
    varchar在存储的时候保留所有空格,不进行任何删除

  8. varchar和char在查询的时候都只会根据where条件中的左侧空格进行判断,右侧末尾的空格会忽略

二、TEXT类型

    TEXT类型是一种特殊的字符串类型,包括TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT,其长度和存储空间的对比下表所示:

     各种TEXT类型的区别在于允许的长度和存储空间不同。因此,在这几种TEXT类型中,根据需求选取既能满足需要又节省空间的类型即可。 

特别注意

  1. 以上各类型无须指定长度!
  2. 允许的长度是指实际存储的字节数,而不是实际的字符个数,比如假设一个中文字符占两个字节, 那么TEXT 类型可存储 65535/2 = 32767  个中文字符,而varchar(100)可存储100个中文字符,实际占200个字节,但varchar(65535) 并不能存储65535个中文字符,因为已超出表达范围(varchar要预留1到2个字节存储这个字符的长度65535×2=131072,2字节整数最大只能到65535)。

    e_text最大长度为255字节,这里创建表的字符集为UTF-8,汉字占3个字节,所以可存储中文字符85个;v_char可存储10个中文字符,占30字节;

create table text_example(e_text tinytext, v_char varchar(10));
insert into text_example values('北国风光,千里冰封,万里雪飘。望长城内外,惟余莽莽;大河上下,顿失滔,山舞银蛇,原驰蜡象,欲与天公试比高。须晴日,看红装素裹,分外妖娆。江山如此多娇 ,引无数英雄竞折腰。惜','北国风光,千里冰封,');

   超出长度时则会报错,这里就不做演示。

 总结:

  1. char长度固定, 即每条数据占用等长字节空间;适合用在身份证号码、手机号码等定。超过255字       节的只能用varchar或者text;
  2. varchar可变长度,可以设置最大长度;适合用在长度可变的属性。(要注意最大长度所占用的字节数会不会超过65535)
  3. text不设置长度, 当不知道属性的最大长度时,适合用text, 能用varchar的地方不用text;
  4. 如果都可以选择,按照查询速度: char最快, varchar次之,text最慢。

这篇关于【MySQL】轻松学习 列的类型定义(三)CHAR与VARCHAR和TEXT类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/160788

相关文章

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

SQL Server 中的 WITH (NOLOCK) 示例详解

《SQLServer中的WITH(NOLOCK)示例详解》SQLServer中的WITH(NOLOCK)是一种表提示,等同于READUNCOMMITTED隔离级别,允许查询在不获取共享锁的情... 目录SQL Server 中的 WITH (NOLOCK) 详解一、WITH (NOLOCK) 的本质二、工作

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地