首页 > 数据库 >MySQL字段长度详解 附实操分析

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

时间:2024-03-05 14:23:00浏览次数:29  
标签:11 varchar 段长度 int 附实 插入 MySQL test tb

一、前言

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

二、字节

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

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

三、字符


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

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

四、字段长度

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

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.创建一张测试表,结构如下。

2.同时向这张表三个字段都插入 123456789,未超过int类型的取值范围,插入成功。
可见不管是int(1)、还是int(4)插入一个位数为9的数都能插入成功,而且显示正常。

3.同时向这张表三个字段都插入 12345678910,超过了int类型的取值范围,插入失败。

4.我们重新修改表结构,将所有字段这里的 填充零 勾选上。保存后会发现,未勾选的无符号也会被勾选上。这里的填充0指的是当你设置了长度比如说int(4),4个长度而你只插入了3位数的值比如 999 时,会自动的在缺少的位数前面补0,查询出来的结果变成 0999。而前面补零的操作在业务场景下,只在值为自然数的时候有意义。所以当你勾选填充零时,这个字段就自动变成了无符号字段,只能存储自然数,取值范围:0~2^32-1。

5.勾选填充零后,只允许存储自然数,插入负数报错。

6.同时向这张表三个字段都插入 999,插入成功。查询出来的结果里,字段不够的位数会补0。

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.创建一张表,结构如下:

2.同时向这张表两个字段都插入7个字符。varchar5字段插入失败,越界。

3.同时向这张表两个字段都插入5个字符。插入成功。

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适用于存储不定长度的字符串比如:地址、个人简介等。在合适的场景下选用合适的类型才是王道。

标签:11,varchar,段长度,int,附实,插入,MySQL,test,tb
From: https://www.cnblogs.com/liyunxi/p/18053965

相关文章

  • mysql 8 修改账号密码
    一进入Mysqlbin目录cmd运行(跳过密码),运行完不要关闭mysqld--console--skip-grant-tables--shared-memory二新打开一个cmdmysqlbin目录下登录,密码输入时,直接回车mysql-uroot-p三修改密码mysql>usemysql;mysql>updateusersetauthentication_string=......
  • Ubuntu2.0解压安装mysql8.0
    https://www.cnblogs.com/dodoye/articles/15501845.html踩过的坑:linux版本和下载的版本不匹配,卸载不完全有些残留 二、解压、安装等dodo@gk-oa:~$tar-xvfmysql-server_8.0.23-1ubuntu20.04_amd64.deb-bundle.tarlibmysqlclient21_8.0.23-1ubuntu20.04_amd64.deblib......
  • mysql8.0 性能优化配置 innodb_buffer_pool_size(配置原则和方式)
    1. BufferPool缓冲池是主内存中的一个区域,InnoDB在访问表和索引数据时会在该区域进行缓存。缓冲池允许直接从内存访问频繁使用的数据,这加快了处理速度。在专用服务器上,通常会将高达80%的物理内存分配给缓冲池。2.简单优化把innodb_buffer_pool_size设置为1G。专用服务......
  • Centos7安装mysql8版本(亲测可用)
    Step1进入MYSQL官网下载https://www.mysql.com/downloads/ MySQLEnterpriseEdition企业版本 需付费,可以试用30天,提供了更多的功能和更完备的技术支持,更适合于对数据库的功能和可靠性要求较高的企业客户。 MySQLClusterCGE高级集群版 需付费,是一个实时开源事......
  • mysql 8 不能启动
    问题:启动systemctlstartmysqld.serviceJobformysqld.servicefailedbecausethecontrolprocessexitedwitherrorcode.See"systemctlstatusmysqld.service"and"journalctl-xe"fordetails.查看状态:systemctlstatusmysqld.service  mysqld.se......
  • 未完成编辑 Linux CentOS7.6使用腾讯Yum源安装MySQL5.7,执行mysql-secure-installation
    学习安装MySQL时发现官方源很慢,试了国内腾讯源快,记录一下LinuxCentOS7.6前置环境:CPU1内存4GB硬盘SCSI20GB网络模式桥接系统内为自动DHCPpingqq.com可通互联网以下为MySQL5.7安装步骤编辑新repo库路径:/etc/yum.repos.d/mysql-community.repovi/etc/yum.repos......
  • 从MySQL到ByteHouse,抖音精准推荐存储架构重构解读
    更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群抖音依靠自身推荐系统为用户推送可能感兴趣的视频内容,其中兴趣圈层是推荐的重要能力,通过理解核心用户的偏好特征,判断两者偏好的相似性,从而构建同类用户的兴趣圈层,实现精准推荐。以往的兴趣圈......
  • day06-Mysql数据库
    Mysql一、概述1.1数据模型关系型数据库RDBMS,由多张二维表组成的数据库1.2SQLDDL:数据定义语言DML:数据操作语言DQL:数据查询语言DCL:数据控制语言,创建用户,控制数据库访问权限二、sql语句2.1DDL2.1.1查询:showdatabases;selectdatabase();2.1.2创建:createda......
  • dpkg安装mysql时失败卸载不掉踩的坑
    原文:https://blog.csdn.net/Camu7s/article/details/43485985nbuntu下彻底卸载mysql:apt-getautoremove--purgemysql-serverapt-getremovemysql-serverapt-getremovemysql-clientapt-getremovemysql-common最后清楚残留数据(important!!!):dpkg-l|grep^rc|awk'{print......
  • MySQL批量更新10万条数据怎么最快?
    如果10万条数据进行批量更新该怎么操作呢?我们一起来看看具体可以怎么做。mysql批量更新如果一条条去更新效率是相当的慢,循环一条一条的更新记录,一条记录update一次,这样性能很差,也很容易造成阻塞。mysql批量更新共有以下四种办法1、.replaceinto批量更新replace into ......