MySQL中varchar(10)和varchar(100)的区别和优缺点[通俗易懂]

MySQL中varchar(10)和varchar(100)的区别和优缺点[通俗易懂]许多使用MySQL的同学都会使用到varchar这个数据类型。初学者刚开始学习varchar时,一定记得varchar是个变长的类型这个知识点,所以很多初学者在设计表时,就会把varchar(X)的长

MySQL中varchar(10)和varchar(100)的区别和优缺点

许多使用MySQL的同学都会使用到varchar这个数据类型。初学者刚开始学习varchar时,一定记得varchar是个变长的类型这个知识点,所以很多初学者在设计表时,就会把varchar(X)的长度设置的非常长,目的也是为了保证以后有更长的数据存储时,能更好的兼容。

于是本来varchar(10)就可以满足当前的存储的长度需求了,改成了varchar(100)。

那么疑问来了:

既然是变长类型,varchar(10)和varchar(100)有什么区别?

先举个例子:如果要存储”hello12345″这个字符串,使用varchar(10)和varchar(100)存储,占用磁盘空间是一样的么?

答案是:占用磁盘的存储空间是一样的。

既然存储时磁盘占用空间一样,还有什么其他的区别吗?

虽然使用varchar(100)和varchar(10)存储”hello12345″字符串占用的磁盘空间一样,但是消耗的内存不一样,更长的列消耗的内存会更多。因为MySQL通常会分配固定大小的内存块来保存内部值。尤其是使用临时表进行排序会操作时,会消耗更多的内存。在使用磁盘进行排序时,也是一样。

所以此时varchar(100) 会消耗更多的内存。

varchar(10)和varchar(100)的优劣势是什么?

因为涉及到文件排序或者基于磁盘的临时表时,更长的列会消耗更多的内存,所以在使用使用时,我们不能太过浪费内存空间,还是需要评估实际使用的长度来设置字符的长度。推荐冗余10%的长度(因业务而异)。

所使用varchar(10)会更加节约内存空间,但是实际业务中字符长度一旦超过10就需要更改表结构,在表数据量特别大时,不易拓展。

而这时使用更长的列:varchar(100)无需更改表结构,业务拓展性更好。

原文地址:https://www.cnblogs.com/ailiailan/archive/2022/03/15/16010369.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5435.html

(0)
上一篇 2023-05-09
下一篇 2023-05-09

相关推荐

  • mysql字段长度不合理影响性能_sql文字与格式字符串不匹配

    mysql字段长度不合理影响性能_sql文字与格式字符串不匹配故事是这样的: 我在对MySQL进行性能测试时,发现CPU使用率接近100%,其中80%us, 16%sys,3%wa,iostat发现磁盘iops2000以下,avgqu-sz不超过3,%util最

    2023-02-06
    144
  • Python工程师必知必会——Numpyany基础知识

    Python工程师必知必会——Numpyany基础知识Python是一种功能丰富而又简单易用的编程语言,已经成为数据科学和机器学习领域的主要语言。在数据科学领域中,NumPy是Python中最重要的工具之一。NumPy是一个Python包,提供了高性能数值运算功能和支持大型多维数组和矩阵的数据结构。它支持很多数学操作,例如线性代数、傅里叶变换、随机数生成等等。

    2024-04-29
    99
  • 使用Navicat Premiun远程连接MySQL失败,报错(10038)[通俗易懂]

    使用Navicat Premiun远程连接MySQL失败,报错(10038)[通俗易懂]远程连接MySQL失败,可能有一下原因: 1、小伙子/小姑凉注意一下你的ip是否输入正确了!! 2、网络或防火墙问题 1)、排查网络问题 使用命令:ping 192.168.1.1 查看网络请求是否超

    2023-02-05
    138
  • MySQL常用命令.md[通俗易懂]

    MySQL常用命令.md[通俗易懂]## 链接数据库
    “`
    ## -h/-u这些后面没有空格
    ./bin/mysql -h[ip地址] -P[端口号] -u[用户名] -p[密码]
    “` ## 查看建表语句
    “`sql
    show

    2022-12-30
    157
  • 使用Python实现数据可视化

    使用Python实现数据可视化数据可视化是将数据转换为图形、图表等形式以便用户更好地理解数据分布规律、数据之间的关系、趋势等信息的过程。Python作为一种高效、灵活的编程语言,具有广泛的应用场景,尤其在数据科学领域被广泛使用。这篇文章将介绍如何使用Python实现数据可视化,包括Matplotlib、Seaborn、Plotly等库的使用。读者可以通过学习文章了解各种库的基本使用,以便在需要时选择合适的工具。

    2024-02-07
    85
  • linux安装Oracle11G「终于解决」

    linux安装Oracle11G「终于解决」
    阅读目录: linux安装Oracle11G 0、下载Orcle11G 1、上传文件到服务器或虚拟机的/install目录下 2、解压文件到当前目录: 3、…

    2023-04-05
    147
  • mysql外键约束怎么写_mysql查询外键约束

    mysql外键约束怎么写_mysql查询外键约束CASCADE:父表delete、update的时候,子表会delete、update掉关联记录; SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为nul…

    2022-12-22
    128
  • 以Python为中心

    以Python为中心Python是一种高级动态类型编程语言。它具有简单易学、代码可读性高、易于维护、支持多种编程范式等优点,因此在广泛的应用领域中具有很高的人气。本文将从不同的方面阐述Python的优点和应用。

    2024-06-27
    43

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注