MySQL 中 int(11) 的 11 表示什么?

在 MySQL 中,int(11) 中的 11 并不表示整数的取值范围,而是用于显示宽度(Display Width)。它的含义和具体影响如下:


1. 显示宽度的定义

  • 显示宽度是指在使用 ZEROFILL 属性时,MySQL 返回查询结果时显示的最小数字宽度。
  • 如果存储的整数值不足指定的宽度,会用零填充到指定宽度。

例如:

CREATE TABLE example (

id INT(11) ZEROFILL

);

INSERT INTO example (id) VALUES (123);

SELECT id FROM example;

结果

00000000123

解释

  • INT(11) 配合 ZEROFILL 使用,表示输出宽度至少为 11 位,不足部分用 0 填充。

2. 显示宽度的影响

  • 显示宽度不会影响实际存储的数据大小,也不会限制可以存储的数值范围。
  • int(11) 的数值范围完全由 INT 类型决定,为 -2^312^31-1(约 -21亿+21亿)。

例如:

  • 存储值为 112345678901,都会被正确保存,宽度只影响带 ZEROFILL 的查询显示。

3. 显示宽度是否必要

  • 在 MySQL 8.0 中,显示宽度已被废弃,对于整数类型(如 TINYINTSMALLINTINTBIGINT),显示宽度不再生效。
  • 原因:显示宽度仅影响数据输出的显示方式,而现代应用通常由客户端程序处理格式化显示,MySQL 保留此功能意义不大。

4. 取值范围与显示宽度的关系

显示宽度与整数类型的取值范围无关,取值范围由数据类型的大小决定:

数据类型 字节大小 有符号取值范围 无符号取值范围
TINYINT 1 -128 ~ 127 0 ~ 255
SMALLINT 2 -32,768 ~ 32,767 0 ~ 65,535
INT 4 -2,147,483,648 ~ 2,147,483,647 0 ~ 4,294,967,295
BIGINT 8 -9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807 0 ~ 18,446,744,073,709,551,615

5. 示例

创建表

CREATE TABLE demo (

id INT(11) ZEROFILL,

value INT(11)

);

插入数据

INSERT INTO demo (id, value) VALUES (123, 4567);

查询数据

SELECT id, value FROM demo;

结果

id value 00000000123 4567
  • id 列因为使用了 ZEROFILL,不足 11 位用 0 补齐。
  • value 列没有 ZEROFILL,显示为实际存储的值。

6. 总结

  1. int(11) 中的 11 表示显示宽度,与数据存储大小或取值范围无关。
  2. 显示宽度仅在配合 ZEROFILL 使用时有效,用于输出固定长度的数值。
  3. 从 MySQL 8.0 开始,显示宽度功能已废弃,建议避免依赖此特性。

MySQL 中 int(11) 的 11 表示什么?的更多相关文章

  1. mysql中int(M) tinyint(M)中M的作用

    原先对mysql不太理解,但也没有报错.但理解的不够深入.这次补上. 原来以为int(11)是指11个字节,int(10)就是10个字节.我错了. http://zhidao.baidu.com/li ...

  2. mysql中int、bigint、smallint、tinyint 长度

    mysql中int.bigint.smallint.tinyint 长度 bigint -2^63 (-9223372036854775808) 到 2^63-1 (92233720368547758 ...

  3. [转]MySQL中int(11)最大长度是多少?

    原文地址:https://blog.csdn.net/allenjay11/article/details/76549503 今天在添加数据的时候,发现当数据类型为 int(11) 时,我当时让用户添 ...

  4. [转载]MySQL中int(11)最大长度是多少?

    原文地址:https://blog.csdn.net/allenjay11/article/details/76549503 今天在添加数据的时候,发现当数据类型为 int(11) 时,我当时让用户添 ...

  5. Mysql中int(1)的误解及说明

    在mysql中使用int相关的数据类型时, 如果不太了解其存储方式, 会产生一些误用的情况. 如: 只保存0-9之间的数字, 可能会直接用int(1). 习惯性的以为int(1)就相当于varchar ...

  6. Mysql中int和varchar类型

    int类型: int bigint smallint 和 tinyint 类型,如果创建新表时没有指定 int(M) 中的M时,默认分别是 : int           -------     in ...

  7. mysql中int转varchar

    这里要注意,cast(XX as varcahr(10))在mysql中不好使,要cast(XX as char(10))这样才好使

  8. Mysql 中 int(3) 和 int(11) 的区别

    [1]int(3) 和 int(11)的区别(思维惯性认知错误) 这里的3或11代表的是存储在数据库中的具体的长度,总以为int(3)只能存储3个长度的数字,int(11)只会存储11个长度的数字. ...

  9. mysql中int(3)与int(11)有什么区别吗?

    注意:这里的M代表的并不是存储在数据库中的具体的长度,以前总是会误以为int(3)只能存储3个长度的数字,int(11)就会存储11个长度的数字,这是大错特错的. 其实当我们在选择使用int的类型的时 ...

  10. MySQL中int(11)的意思

    参考文献:https://segmentfault.com/a/1190000012479448 int(11)中的11代表的是字符的显示宽度,在字段类型为int时,无论你显示宽度设置为多少,int类 ...

随机推荐

  1. Calendar日历类(抽象类)的使用

    4. java.util.Calendar( 日历)类 类 Calendar是一个抽象基类,主用用于完成日期字段之间相互操作的功能. 获取Calendar实例的方法 使用Calendar.get ...

  2. ctfshow 红包题第七弹 .git

    .git源码泄露 发现有后们 flag在上级目录里面 直接Letmein=show_source('../flag.txt');就出来了

  3. uni-app组件 信息列表组件

    之前我一直在,要想提高自己的代码质量, 就一定要封装自己的组件, 所以我就尽量使用自己的组件.这样可以提高自己的效率 写组件的好处:减少代码的冗余 封装组件的时候,为了不让子元素的padding, 影 ...

  4. flutter-使用flutter_app_upgrade进行版本更新要点

  5. [ABC227E] Swap 题解

    考试一道题题解. 30pts:枚举所有串,\(check\) 是否可行. 60pts:做 \(bfs\),暴力推演变化过程,用 \(map\) 去重,时间复杂度 \(O(nC_{n}^{n/3}C_{ ...

  6. FANUC发那科机器人控制箱维修操作流程

    FANUC发那科机器人在工业自动化领域中占有重要地位,其高效.稳定和精确的性能赢得了众多用户的青睐.然而,随着使用时间的增长,可能会出现FANUC机器人控制柜故障,影响到发那科机器人的正常运行.本文将 ...

  7. Vue实现企业微信扫码登录

        Vue实现企业微信扫码登录   企业微信扫码登录原理 构建企业微信登录二维码 获取访问令牌access_token 请求方式:GET(HTTPS)请求URL:https://qyapi.wei ...

  8. oracle - [01] 安装部署

    超级详细的Oracle安装图文详解!手把手教会您从下载到安装! https://blog.csdn.net/weixin_46329056/article/details/125451601

  9. 数据挖掘 | 数据隐私(3) | 差分隐私 | 差分隐私概论(上)(Intro to Differential Privacy 1)

    L3-Intro to Differential Privacy 从这节课开始就要介绍差分隐私算法了. 随机响应(Randomized Response) 场景提出 假若你是某一门课的教授,你希望统计 ...

  10. 【论文随笔】基于会话的推荐系统构建方法调查(Survey On Methods For Building Session-Based Recommender Systems)

    前言 今天读的论文为一篇于2023年发表在国际开放信息技术杂志(International Journal of Open Information Technologies)的论文,文章是关于构建基于 ...