MySQL字段长度详解 附实操分析

这篇具有很好参考价值的文章主要介绍了MySQL字段长度详解 附实操分析。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


一、前言

搜了下有关方面的内容发现良莠不齐。大部分人对这方面的内容也比较模糊,先附上MYSQL常用类型图。

MySQL字段长度详解 附实操分析

二、字节

首先需要达成共识的是:1个Byte字节等于8个bit位bit是最小一级的信息单位,可以表示一个0或1(即二进制);
那么由此我们可以计算,一个字节其实可以表示256种取值。

计算方式如下:
	一个Byte是8位二进制数,既然是二进制,所以每一位只有两种可能:01
	取值从[00000000]→[11111111]根据排列组合,2^8 = 256 所以有256种取值。

三、字符

字符其实是一个统称,字母、数字、运算符号、标点符号和其他符号,以及一些功能性符号都属于字符。比如:&、中、A。
那到底一个字符占用多少字节呢?这个问题其实取决于数据库所采用的编码格式。
一般来说一个英文字符(A、b)都占用1个字节。在UTF8编码下,一个中文汉字占3个字节;在GBK编码下,一个中文汉字占用2个字节。

完了,gg了!   ==> 七个字符
hello,世界    ==> 八个字符

四、字段长度

这个概念来源于当新建或者编辑表,设计字段会有涉及。比如下表中的int(11)、varchar(255),括号中的11、255指的就是字段长度。
MySQL字段长度详解 附实操分析

CREATE TABLE `sys_test` (
  `t_id` int(11) NOT NULL COMMENT '主键ID',
  `name` varchar(255) DEFAULT NULL COMMENT '姓名',
  `age` tinyint(4) DEFAULT NULL COMMENT '年龄',
  PRIMARY KEY (`t_id`)
) 

注意:这里的字段长度准确来说指的是显示的宽度,不同数据类型对这里的宽度处理也不一样。

这也是很多人模糊的地方,这里加上实操与例子进行说明。

4.1 例 int(1) 、int(4) 、int(11)

数值类型这里以int(1) 、int(4) 、int(11)为例,其实这三者能存储的数字范围是一样的,都是只能存储 负2^31 到 2^31-1 或者 无符号的 0 到 2^32-1

  1. 创建一张测试表,结构如下。
    MySQL字段长度详解 附实操分析
  2. 同时向这张表三个字段都插入 123456789,未超过int类型的取值范围,插入成功。
    可见不管是int(1)、还是int(4)插入一个位数为9的数都能插入成功,而且显示正常。
    MySQL字段长度详解 附实操分析
  3. 同时向这张表三个字段都插入 12345678910,超过了int类型的取值范围,插入失败。
    MySQL字段长度详解 附实操分析
  4. 我们重新修改表结构,将所有字段这里的 填充零 勾选上。保存后会发现,未勾选的无符号也会被勾选上。这里的填充0指的是当你设置了长度比如说int(4),4个长度而你只插入了3位数的值比如 999 时,会自动的在缺少的位数前面补0,查询出来的结果变成 0999。而前面补零的操作在业务场景下,只在值为自然数的时候有意义。所以当你勾选填充零时,这个字段就自动变成了无符号字段,只能存储自然数,取值范围:0~2^32-1。
    MySQL字段长度详解 附实操分析
  5. 勾选填充零后,只允许存储自然数,插入负数报错。
    MySQL字段长度详解 附实操分析
  6. 同时向这张表三个字段都插入 999,插入成功。查询出来的结果里,字段不够的位数会补0。
    MySQL字段长度详解 附实操分析
CREATE TABLE `tb_int_test` (
  `int1` int(1) DEFAULT NULL,
  `int4` int(4) DEFAULT NULL,
  `int11` int(11) DEFAULT NULL
)

-- 插入成功
INSERT into tb_int_test VALUES(123456789,123456789,123456789)

-- 查询结果
SELECT * FROM tb_int_test

-- 插入失败 越界
INSERT into tb_int_test VALUES(12345678910,12345678910,12345678910)

-- 插入失败 越界
INSERT into tb_int_test VALUES(-1,-2,-3)

-- 插入成功。查询出来的结果里,字段不够的位数会补0。
INSERT into tb_int_test VALUES(999,999,999)

综上,我们可以得出一个结论:

在数值类型里面:在满足取值范围的前提下,字段的长度指的是当该字段被设置为填充零、无符号时,最多填充零的数量。
int(1) 最多填充1个0、int(4)最多填充4个0…int(M)经常搭配填充零(zerofill)使用,达到补零显示的功能。

4.2 为什么int常被设置为int(11)

通过上述结论,我们可知要使int(M)中的M取值有意义,就必须要在满足int类型取值范围的前提下进行。
而int类型能存储 负2^31 到 2^31-1 或者 无符号的 0 到 2^32-1。即 -2147483648 ~ 2147483647 或者 0 ~ 4294967295
不考虑无符号的情况下,-2147483648的位数为11(这里的负号也有一位),设置为int(11)意义在此,而当考虑无符号的情况下,只需要10位,设置int(10)就可以了。

4.3 varchar(5) 与 varchar(255)

  1. 创建一张表,结构如下:
    MySQL字段长度详解 附实操分析
  2. 同时向这张表两个字段都插入7个字符。varchar5字段插入失败,越界。
    MySQL字段长度详解 附实操分析
  3. 同时向这张表两个字段都插入5个字符。插入成功。
    MySQL字段长度详解 附实操分析
CREATE TABLE `tb_varchar_test` (
  `varchar255` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `varchar5` varchar(5) COLLATE utf8_unicode_ci DEFAULT NULL
) 
-- 插入7个字符插入失败
INSERT into tb_varchar_test VALUES("钓鱼岛是中国的","钓鱼岛是中国的")

-- 插入5个字符插入成功
INSERT into tb_varchar_test VALUES("我是中国人","我是中国人")

综上,我们可以得出一个结论:

在字符类型中,char(1)、varchar(255),这里的字符长度指的是能插入数据的最大宽度,超过这个宽度插入报错。

4.4 char 与 varchar

char的长度是固定的,而varchar的长度是可变的。
也就是说,定义一个char(10) 和 varcha(10),如果存进去的是csdn,而varchar消耗的长度为4,char所占的长度固定为10,除了字符csdn外后面会补充六个空格占位符,取数据的时候,char类型的要用trim()去掉多余的空格,而varchar是不需要的。

char的存取效率要比varchar要快得多,因为其长度固定,方便程序的存储与查找;varchar空间利用率高,而char读取速度快,但以空间换取时间效率,因为其长度固定,所以难免会有多余的空格占位符占据空间。

所以char适用于存储固定长度的字符串比如:身份证号、手机号等;varchar适用于存储不定长度的字符串比如:地址、个人简介等。在合适的场景下选用合适的类型才是王道。文章来源地址https://www.toymoban.com/news/detail-498687.html

到了这里,关于MySQL字段长度详解 附实操分析的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 面试官:说一说mysql的varchar字段最大长度?

    在mysql建表sql里,我们经常会有定义 字符串 类型的需求。 比方说user表里的名字,就是个字符串。mysql里有两个 类型 比较适合这个场景。 char和varchar。 声明它们都需要在字段边上加个数组,比如 char(100) 和 varchar(100) ,这个100是指当前字段能放的 最大字符数 。 char和varchar的

    2023年04月16日
    浏览(40)
  • mysql的group_concat字段的长度限制

    在使用group_concat进行数据分组查询的时候会出现数据只出现一部分的状况,这种是因为group_concat这个字段的字符长度不够,在信息超高这个长度的时候会自动的截取,如果想要解决这个问题的话需要进行额外的设置 修改mysql配置文件my.ini ,默认情况下是没有group concat max len项

    2024年02月13日
    浏览(43)
  • 34亿的mysql表如何优雅的扩字段长度兵并归档重建

    业务背景: 该系统有一张表数据量已达到34亿,并且有个字段长度不够,导致很多数据无法插入。因为业务只要保留近2个月数据即可,所以需要接下来需要做2点:1,扩字段长度 2,只保留近2个月的数据。 于是有了接下来的方案: 1,delete  2个月 之前的数据 ,然后扩字段长

    2024年02月10日
    浏览(29)
  • PHP分析二维数据表(长度|数字字段|空值|纯姓名|英文用户名|科学计数|是否等长|是否唯一)

    先看图,后有完整代码    仅供娱乐!

    2024年02月22日
    浏览(62)
  • 数据结构之进阶二叉树(二叉搜索树和AVL树、红黑树的实现)超详细解析,附实操图和搜索二叉树的实现过程图

    绪论​ “生命有如铁砧,愈被敲打,愈能发出火花。——伽利略”;本章主要是数据结构 二叉树的进阶知识,若之前没学过二叉树建议看看这篇文章一篇掌握二叉树,本章的知识从浅到深的 对搜索二叉树的使用进行了介绍和对其底层逻辑的实现进行了讲解 ,希望能对你有所

    2024年02月04日
    浏览(47)
  • 《TCP/IP详解 卷一:协议》第5章的IPv4数据报的总长度字段出现“不需要大于576字节的IPv4数据报“相关内容的解释

    《TCP/IP详解 卷一:协议》第5章的IPv4数据报的总长度字段的一些解释,出现以下内容(有省略): ....另外,主机不需要接收大于576字节的IPv4数据报.....以避免576字节的IPv4限制。 英文原文的内容(有省略): Furthermore, a host is not required to be able to receive an IPv4 datagram larger tha

    2024年02月06日
    浏览(52)
  • Java【手撕滑动窗口】LeetCode 209. “长度最小子数组“, 图文详解思路分析 + 代码

    各位读者好, 我是小陈, 这是我的个人主页, 希望我的专栏能够帮助到你: 📕 JavaSE基础: 基础语法, 类和对象, 封装继承多态, 接口, 综合小练习图书管理系统等 📗 Java数据结构: 顺序表, 链表, 堆, 二叉树, 二叉搜索树, 哈希表等 📘 JavaEE初阶: 多线程, 网络编程, TCP/IP协议, HTTP协议

    2024年02月11日
    浏览(44)
  • 使用oracle修改表字段长度

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 Oracle是一种关系数据库管理系统(RDBMS),由美国Oracle公司开发和维护。它是全球最受欢迎和广泛使用的商业数据

    2024年02月10日
    浏览(37)
  • php开发实战分析(1):mysql操作字段(添加、删除、修改,多数据表中新增多个字段)

    要删除MySQL数据库中的字段,您需要执行以下步骤: 连接到MySQL数据库。您可以使用MySQL的PHP扩展或PDO(PHP数据对象)来实现连接。 使用MySQL扩展连接示例: 使用PDO连接示例: 构造SQL语句删除字段。使用 ALTER TABLE 语句来删除字段。在语句中使用 DROP COLUMN 指定要删除的

    2024年02月16日
    浏览(48)
  • Oracle字段长度不足位数补零

    有时候从数据库中取出的月份值是1,而不是01,该怎么办呢 注意 1、第一个参数为待补字符;第二个参数表示补齐后的总字符长度;第三位表示不足时补什么字符; 2、lpad是左侧补0,右侧补0可用rpad

    2024年02月12日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包