【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

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据