mysql中varchar存储容量

  • 1、varchar能存多少汉字、数字?
  • 2、varchar的最大长度是多少呢?
  • 3、字符、字节、位,之间的关系?
  • 4、mysql字段类型存储需要多少字节?
  • 5、varchar(100)和varchar(10)的区别在哪里?

1、varchar能存多少汉字、数字?

  • 具体还是要看版本的,一个字符占用3个字节 ,一个汉字(包括数字)占用3个字节=一个字符

  • 4.0版本以下,varchar(100),指的是100字节,如果存放UTF8汉字时,只能存33个(每个汉字3字节)

  • 5.0版本以上,varchar(100),指的是100字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放100个。

  • UTF8编码中一个汉字(包括数字)占用3个字节

  • GBK编码中一个汉字(包括数字)占用2个字节

2、varchar的最大长度是多少呢?

mysql的vachar字段的类型虽然最大长度是65535,但是并不是能存这么多数据,最大可以到65533,其中需要1到2个字节来存储数据长度(如果列声明的长度超过255,则使用两个字节来存储长度,否则1个)字节,当不允许非空字段的时候(因为要用一个字节来存储不可为空的标识),当允许非空字段的时候只能到65532(省下了存储非空的那个字节)。

行中可以用的字节数如下计算:(参考文档:https://www.jianshu.com/p/ee1e4b14c5e7 )

字段非空时候:varchar(65535) -2 bytes (存储长度,按2个算) - 1byte (latin1类型) - 1 (null byte)=65531 字节可以用

减1的原因是实际行存储从第二个字节开始’;

字段可以空时候:varchar(65535) -2 bytes (存储长度,按2个算) - 1byte (latin1类型) =65532 字节可以用

根据这个最大字节数,以及编码方式,可以计算能存储的汉字数。

3、字符、字节、位,之间的关系?

  1. 位:
    数据存储的最小单位。每个二进制数字0或者1就是1个位;
  2. 字节:
    8个位构成一个字节;

即:1 byte (字节)= 8 bit(位);

1 KB = 1024 B(字节);
1 MB = 1024 KB; (2^10 B)
1 GB = 1024 MB; (2^20 B)
1 TB = 1024 GB; (2^30 B)

  1. 字符:

a、A、中、+、*、の…均表示一个字符;
一般 utf-8 编码下,一个汉字 字符 占用 3 个 字节;数字属于汉字,和汉字占用一样字节。
一般 gbk 编码下,一个汉字 字符 占用 2 个 字节;

4、mysql字段类型存储需要多少字节?

数字类型
列类型 需要的存储量
TINYINT 1 字节
SMALLINT 2 个字节
MEDIUMINT 3 个字节
INT 4 个字节
INTEGER 4 个字节
BIGINT 8 个字节
FLOAT(X) 4 如果 X < = 24 或 8 如果 25 < = X < = 53
FLOAT 4 个字节
DOUBLE 8 个字节
DOUBLE PRECISION 8 个字节
REAL 8 个字节
DECIMAL(M,D) M字节(D+2 , 如果M < D)
NUMERIC(M,D) M字节(D+2 , 如果M < D)
日期和时间类型
列类型 需要的存储量
DATE 3 个字节
DATETIME 8 个字节
TIMESTAMP 4 个字节
TIME 3 个字节
YEAR 1 字节
串类型
列类型 需要的存储量
CHAR(M) M字节,1 <= M <= 255
VARCHAR(M) L+1 字节, 在此L <= M和1 <= M <= 255
TINYBLOB, TINYTEXT L+1 字节, 在此L< 2 ^ 8
BLOB, TEXT L+2 字节, 在此L< 2 ^ 16
MEDIUMBLOB, MEDIUMTEXT L+3 字节, 在此L< 2 ^ 24
LONGBLOB, LONGTEXT L+4 字节, 在此L< 2 ^ 32
ENUM(‘value1’,‘value2’,…) 1 或 2 个字节, 取决于枚举值的数目(最大值65535)
SET(‘value1’,‘value2’,…) 1,2,3,4或8个字节, 取决于集合成员的数量(最多64个成员)
text与blob的区别在于:text不能存储图片。blob是二进制流,text是非二进制。

mysql 的二进制数据类型 BINARY, VARBINARY, BLOB 都没有字符集的概念。

5、varchar(100)和varchar(10)的区别在哪里?

一般初学会认为,二者占用的空间是一样的。比如说我存储5个char,二者都是实际占用了5个char了【不准确的想法:varchar在实际存储的时候会多一个byte用来存放长度】。
但是深入一下,设计数据库的时候,二者一样吗?
答案是否定的【至少varchar类型需要在数据之前利用一个或者两个字节来存储数据的长度】并且二者在内存中的操作方式也是不同的,下面的例子中有体现(例子链接:看下面的例子。 )
如现在用户需要存储一个地址信息。根据评估,只要使用100个字符就可以了。但是有些数据库管理员会认为,反正Varchar数据类型是根据实际的需要来分配长度的。还不如给其大一点的呢。为此他们可能会为这个字段一次性分配200个字符的存储空间。这VARCHAR(100)与VARCHAR(200)真的相同吗?

结果是否定的。虽然他们用来存储90个字符的数据,其存储空间相同。但是对于内存的消耗是不同的。对于VARCHAR数据类型来说,硬盘上的存储空间虽然都是根据实际字符长度来分配存储空间的,但是对于内存来说,则不是。其时使用固定大小的内存块来保存值。简单的说,就是使用字符类型中定义的长度,即200个字符空间。显然,这对于排序或者临时表(这些内容都需要通过内存来实现)作业会产生比较大的不利影响。解释可以参见这里。如果不想看解释,我这里大概说下:假设VARCHAR(100)与VARCHAR(200)类型,实际存90个字符,它不会对存储端产生影响(就是实际占用硬盘是一样的)。但是,它确实会对查询产生影响,因为当MySql创建临时表(SORT,ORDER等)时,VARCHAR会转换为CHAR,转换后的CHAR的长度就是varchar的长度,在内存中的空间就变大了,在排序、统计时候需要扫描的就越多,时间就越久。

所以如果某些字段会涉及到文件排序或者基于磁盘的临时表时,分配VARCHAR数据类型时仍然不能够太过于慷慨。还是要评估实际需要的长度,然后选择一个最长的字段来设置字符长度。如果为了考虑冗余,可以留10%左右的字符长度。千万不能认为其为根据实际长度来分配存储空间,而随意的分配长度,或者说干脆使用最大的字符长度。
----------------------------------char------------------------------------------
1、从碎片角度进行考虑,使用CHAR字符型时,由于存储空间都是一次性分配的。为此某个字段的内容,其都是存储在一起的。单从这个角度来讲,其不存在碎片的困扰。而可变长度的字符数据类型,其存储的长度是可变的。当其更改前后数据长度不一致时,就不可避免的会出现碎片的问题。故使用可变长度的字符型数据时,数据库管理员要时不时的对碎片进行整理。如执行数据库导出导入作业,来消除碎片。
2、考虑其长度的是否相近,如果某个字段其长度虽然比较长,但是其长度总是近似的,如一般在90个到100个字符之间,甚至是相同的长度。此时比较适合采用CHAR字符类型。比较典型的应用就是MD5哈希值。当利用MD5哈希值来存储用户密码时,就非常使用采用CHAR字符类型。因为其长度是相同的。另外,像用来存储用户的身份证号码等等,一般也建议使用CHAR类型的数据。
另外请大家考虑一个问题,CHAR(1)与VARCHAR(1)两这个定义,会有什么区别呢?虽然这两个都只能够用来保存单个的字符,但是VARCHAR要比CHAR多占用一个存储位置。这主要是因为使用VARCHAR数据类型时,会多用1个字节用来存储长度信息。这个管理上的开销char字符类型是没有的。

---------------------------------总结---------------------------------------------

二者在磁盘上存储占的空间是一样的。区别有二。第一、一个变长一个固定长度。第二、在内存中的操作方式,varchar也是按照最长的方式在内存中进行操作的。比如说要进行排序的时候,varcahr(100)是按照100这个长度来进行的。

mysql中varchar能存多少汉字、数字,以及varchar(100)和varchar(10)的区别相关推荐

  1. mysql中12e10等于多少_一篇文章看懂mysql中varchar能存多少汉字、数字,以及varchar(100)和varchar(10)的区别...

    看完这篇文章,你能搞清楚以下问题: 1.varchar(100)和varchar(10)的区别在哪里? 2.varchar能存多少汉字.数字? 3.varchar的最大长度是多少呢? 4.字符.字节. ...

  2. MySQL中的char和varcharmysql中varchar能存多少汉字、数字,以及varchar(100)和varchar(10)的区别

    1.varchar能存多少汉字.数字? 具体还是要看版本的,一个字符占用3个字节 ,一个汉字(包括数字)占用3个字节=一个字符 4.0版本以下,varchar(100),指的是100字节,如果存放UT ...

  3. Excel日期格式改成文本格式后日期变成数字的解决方法;在mysql中处理由Excel导入的数字日期(不是时间戳)的解决方法。

    Excel常规格式下的日期会转化成自"1900/1/0"开始的天数,如41374之类的. 在Excel中处理方式如下,处理后点击Enter键确定. 若想除去Excel函数,则复制该 ...

  4. mysql 手机号 字段_2021-01-06:mysql中,我存十亿个手机号码,考虑存储空间和查询效率,用什么类型的字段去存?...

    福哥答案2021-01-06: [答案来自此链接:](https://www.zhihu.com/question/438078173) 首先提出假设: 考虑一下这几个问题: 手机号码都是数字吗? 都 ...

  5. 手机号码 mysql 存储类型_2021-01-06:mysql中,我存十亿个手机号码,考虑存储空间和查询效率,用什么类型的字段去存?...

    福哥答案2021-01-06: 答案来自此链接: 首先提出假设: 考虑一下这几个问题: 手机号码都是数字吗? 都是中国的手机号码吗? 会按照手机号等值查询吗? 会按照手机号范围查询吗? 需要手机号列唯 ...

  6. 每日一面 - mysql中,我存十亿个手机号码,考虑存储空间和查询效率,怎么设计?

    问题参考自:https://www.zhihu.com/question/438078173,以下解答思路为个人原创 首先提出假设: 手机号码不会更新,只会插入和删除. 查询包括精确查询某个手机号是否 ...

  7. mysql 存电话号码应该用哪个字段_2021-01-06:mysql中,我存十亿个手机号码,考虑存储空间和查询效率,用什么类型的字段去存?...

    福哥答案2021-01-06: 答案来自此链接: 首先提出假设: 考虑一下这几个问题: 手机号码都是数字吗? 都是中国的手机号码吗? 会按照手机号等值查询吗? 会按照手机号范围查询吗? 需要手机号列唯 ...

  8. mysql中如何求字段的个数字_求高手帮小弟解决一下!关于mysql字段中数字提取求和的问题?...

    例如表1中的No字段是字符串类型,no字段中包含数字及符号,如20+1.5,8+5+4等 那么有办帮法提取出20,1.5,8,5,4这些数字来进行求和等于38.5吗?语句怎么样写? 解决方案 30 提 ...

  9. 怎么在mysql中打开表存信息,我应该如何存储用户的“收藏夹”在mySQL表?

    I keep reading that I should store this in a separate table "with one value per line". Wha ...

最新文章

  1. 通过Java代码实现图片的放大和缩小
  2. asp.net中长内容自动分页的实现
  3. [unreal4入门系列之十一] 在UE4中编写C++代码控制角色
  4. HMAC(2)哈希运算消息认证码HMAC
  5. label美化css,表单label美化代码
  6. 为什么python安装不了numpy库_python 安装与numpy matplotlib 等库安装
  7. 记录之tensorflow和pytorch中的取范数归一化操作
  8. 解决webview调用 goBack() 返回上一页自动刷新闪白的情况
  9. java一年包装_java回顾之包装类
  10. Exchange收件人管理
  11. c语言mysql自动重连接_c++操作mysql数据库
  12. jquer案例2:改变元素的样式、复选框、下拉框 省份的选择
  13. android 字符串 时间格式化,Android 获取年月日时分秒 格式化指定时间字符串
  14. 三大运营商移动电话用户总数公布了 同比增长6.2%
  15. 读后感:软件测试经验与教训
  16. java cookie共享_cookie共享
  17. 收下这10个终身学习的资源号,Max你的工作效率
  18. micropython ide 8266_老外开发的MicroPython IDE,可用于开发ESP8266
  19. 中文拼音表,完全包括GB2312字库中的字(除极少数生僻字)
  20. Unmapped Spring configuration files found.

热门文章

  1. 麒麟桌面系统搭建ftp服务
  2. react循环渲染数据
  3. springboot中starter和parent的区别
  4. 非计算机专业的大学生有必要考全国计算机等级证书吗?
  5. 【Unity3D】动态路径特效
  6. Hadoop集群搭建教程(超级版本2.0)
  7. 边缘计算、雾计算和云计算
  8. leetcode--458. 可怜的小猪
  9. 关于ITIL Foundation和ITIL Expert的考证路径介绍
  10. C# delegate、event、Action、Func使用案例解析