MySQL varchar(n)能存储几个汉字

 更新时间:2023年05月23日 08:23:32   作者:酷酷  
这篇文章主要介绍了MySQL varchar(n)能存储几个汉字,MySQL中varchar(n)表示n个字符,无论汉字和英文,Mysql都能存入n个字符,仅是实际字节长度有所区别,本文给大家介绍的非常详细,需要的朋友可以参考下

1  前言

我们本节看一个小问题,就是我们平时用的varchar(n)能存储几个汉字。

2  一个中文汉字占多少字节与编码有关

在mysql中,一个中文汉字所占的字节数与编码格式有关:如果是GBK编码,则一个中文汉字占2个字节;如果是UTF8编码,则一个中文汉字占3个字节,而英文字母占1字节。

  • UTF8:一个中文汉字=3个字节
  • GBK:一个中文汉字=2个字节

utf-8, 英文字母1字节

3  varchar(n)能存储几个汉字

MySQL中varchar(n)表示n个字符,无论汉字和英文,Mysql都能存入n个字符,仅是实际字节长度有所区别。

对于utf8字符集:

length返回字节数,char_length返回字符数。

对于gbk字符集而言:

说明:

UTF-8:Unicode Transformation Format-8bit,允许含BOM,但通常不含BOM。是用以解决国际上字符的一种多字节编码,它对英文使用8位(即一个字节),中文使用24为(三个字节)来编码。UTF-8包含全世界所有国家需要用到的字符,是国际编码,通用性强。UTF-8编码的文字可以在各国支持UTF8字符集的浏览器上显示。如,如果是UTF8编码,则在外国人的英文IE上也能显示中文,他们无需下载IE的中文语言支持包。

GBK 是国家标准GB2312基础上扩容后兼容GB2312的标准。GBK的文字编码是用双字节来表示的,即不论中、英文字符均使用双字节来表示,为了区分中文,将其最高位都设定成1。GBK包含全部中文字符,是国家编码,通用性比UTF8差,不过UTF8占用的数据库比GBD大。

GBK、GB2312等与UTF8之间都必须通过Unicode编码才能相互转换:

GBK、GB2312 --> Unicode --> UTF8
 
UTF8 --> Unicode -> GBK、GB2312
  • GB2312是GBK的子集,GBK是GB18030的子集
  • GBK是包括中日韩字符的大字符集合
  • 为了避免所有乱码问题,应该采用UTF-8,将来要支持国际化也非常方便
  •  UTF8可以看作是大字符集,它包含了大部分文字的编码。
  • 使用UTF8的一个好处是其他地区的用户(如香港台湾)无需安装简体中文支持就能正常观看你的文字而不会出现乱码。

gb2312是简体中文的码

gbk支持简体中文及繁体中文

big5支持繁体中文

utf8支持几乎所有字符

4  小结

在字符集为UTF-8的情况下:

  • 若 MySQL version < 4.1:VARCHAR以字节为单位存储,假设全部为常用汉字,则VARCHAR(255)共可存放约85个汉字。
  • 若 MySQL version >= 4.1:VARCHAR以字符为单位存储,假设全部为常用汉字,则VARCHAR(255)可以存放255个汉字。

当然,现在MySQL基本都大于4.1版本的,所以说MySQL中varchar(n)表示n个字符,无论汉字和英文,Mysql都能存入n个字符,仅是实际字节长度有所区别。

到此这篇关于MySQL varchar(n)能存储几个汉字的文章就介绍到这了,更多相关MySQL varchar(n)存储几个汉字内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • MySQL中EXPLAIN命令详解

    MySQL中EXPLAIN命令详解

    在这里我们将介绍的是MySQL中EXPLAIN解释命令,希望对大家有所帮助
    2014-08-08
  • Mysql报Table 'mysql.user' doesn't exist问题的解决方法

    Mysql报Table 'mysql.user' doesn't exist问题的解

    这篇文章主要给大家介绍了关于Mysql报Table 'mysql.user' doesn't exist问题的解决方法,初学者可能会遇到这个问题,文中通过图文将解决方法介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • WIN10下cmd如何查看编码方式,命令行窗口修改UTF-8编码

    WIN10下cmd如何查看编码方式,命令行窗口修改UTF-8编码

    这篇文章主要介绍了WIN10下cmd如何查看编码方式,命令行窗口修改UTF-8编码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • B-树的删除过程介绍

    B-树的删除过程介绍

    今天小编就为大家分享一篇关于B-树的删除过程介绍,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • 在Mac系统上配置MySQL以及Squel Pro

    在Mac系统上配置MySQL以及Squel Pro

    给大家讲述一下如何在MAC苹果系统上配置MYSQL数据库以及Squel Pro的方法。
    2017-11-11
  • mysql函数全面总结

    mysql函数全面总结

    这篇文章主要介绍了mysql函数,下面文章从MySQL常用的函数开始介绍、还有数值函数,利用举例说明的形式展开内容,需要的朋友可以参考一下
    2021-11-11
  • Mysql使用存储过程快速添加百万数据的示例代码

    Mysql使用存储过程快速添加百万数据的示例代码

    这篇文章主要介绍了Mysql使用存储过程快速添加百万数据,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • Mysql的语句生成后门木马的方法

    Mysql的语句生成后门木马的方法

    这篇文章主要介绍了Mysql的语句生成后门木马的方法,大家不要随意搞破坏哦,小伙伴们学习下就好了。
    2015-04-04
  • MySQL 表字段太多超长问题解决方案

    MySQL 表字段太多超长问题解决方案

    在设计MySQL数据库时,常遇到表字段超长问题,这是由字段数量过多或字段定义过长引起的,MySQL对字段数量和行大小有严格限制,超过限制将无法正常操作,本文就来介绍一下解决方法,感兴趣的可以了解一下
    2024-10-10
  • MySQL分库分表与分区的入门指南

    MySQL分库分表与分区的入门指南

    这篇文章主要给大家介绍了关于MySQL分库分表与分区的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04

最新评论