`
aawty
  • 浏览: 32436 次
  • 性别: Icon_minigender_2
  • 来自: 上海
社区版块
存档分类
最新评论

mysql varchar长度的含义

阅读更多

    今天发现项目中有的数据不能插入到mysql数据库中。查看日志报错:Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'name' at row 1。原来name长度不够,项目中name定义为varcahr(30),目测了一下插入的数据确实挺长,就去name表数据源中查找最长的name长度是多少,一开始用的是length函数<!--StartFragment-->

SELECT max(length(name))FROM user

发现最长达到90了。然后去现在要插入的表中查,发现最长竟然达到46,可以超过mysql自己定义的长度,查了一圈发现了真相:

    原来Mysqlvarchar(n)和char(n)表示n个字符,无论汉字和英文,Mysql都能存入n个字符,仅是实际字节长度有所区别,它可以直接存储 n 个汉字. 而不是 n/3或者 n/2 个,mysql 屏蔽了具体的存储细节,而直接以实际字符的个数来决定char存储的个数。而length函数得到的是编码以后字符实际长度。所以这场风波是因为计算单位不一致引起的。

    如果希望查看name中最长汉字数,应该用char_length:

select max(char_length(name)) FROM user
select * from user where char_length(name)=(select max(char_length(name)) FROM user)

还复习了一些其他的sql语句:

查看数据库中引擎信息:

show engines;

查看数据库版本:

select version();

查看数据库表详细信息(包含使用引擎,索引):  

showcreatetableuser;
分享到:
评论

相关推荐

    Mysql中varchar长度设置方法

    在MySQL中,`VARCHAR`是一种用于存储可变长度字符串的数据类型,它的长度设置是非常关键的,因为它直接影响到存储空间的使用效率和数据的正确性。`VARCHAR`的长度设置方法是通过在类型名后面括号内指定最大字符数,...

    MySQL动态修改varchar长度的方法

    在MySQL中,`VARCHAR`类型用于存储可变长度的字符串,它相较于`CHAR`类型更加节省空间,因为它只存储实际输入的数据长度。然而,在数据库设计过程中,有时可能会遇到需要动态修改`VARCHAR`字段长度的情况,这通常是...

    Mysql varchar大小长度问题介绍

    MySQL中的VARCHAR类型是一种可变长度的字符串数据类型,它在存储空间上相比固定长度的CHAR类型更为节省。本文将深入探讨VARCHAR类型的大小长度问题及其在不同版本和编码下的限制。 首先,VARCHAR字段的长度限制主要...

    mysql VARCHAR的最大长度到底是多少

    在MySQL中,VARCHAR长度是通过一个或两个字节来表示的,具体取决于列的最大长度: - 如果VARCHAR长度小于256,则只需要一个字节来存储长度信息。 - 如果长度大于255且小于65,536(2^16),则需要两个字节来存储长度...

    对比MySQL中int、char以及varchar的性能

    然而,无论是char(c8)、varchar(s8)还是它们的4字节版本,它们之间的性能差距并不明显,这表明在全表扫描的情况下,数据的长度对查询速度的影响不大。 当为这些字段创建索引后,性能差距进一步缩小。char和varchar...

    GP数据库表结构转mysql库、oracle库 varchar类型字段长度批量处理excel_MYSQL_oracle_数据库

    在Oracle到MySQL的转换中,除了varchar长度之外,还需要考虑其他差异,比如数据类型的不同(如Oracle的NUMBER与MySQL的DECIMAL)、事务隔离级别、索引策略等。对于varchar字段,可能需要在转换前对源数据进行分析,...

    char和varchar在mysql中的效率怎样.docx

    在MySQL数据库中,`CHAR`和`VARCHAR`是两种常见的字符串数据类型,它们在存储和处理数据时具有不同的效率特点。理解这两种类型的差异对于优化数据库性能至关重要。 `CHAR`是一种固定长度的数据类型,这意味着无论...

    php判断输入不超过mysql的varchar字段的长度范围

    在开发过程中,处理数据库的输入验证是一项重要的工作,尤其是针对MySQL数据库中的varchar类型字段,我们需要确保输入的数据长度不会超过字段定义的限制。本文将详细讨论如何使用PHP判断输入长度是否不超过MySQL中...

    mysql varchar类型求和实例操作

    在MySQL数据库中,`VARCHAR`类型通常用于存储可变长度的字符串数据,如文本或字母数字数据。然而,当你需要对这些数据进行数值计算,比如求和时,问题就会出现,因为`VARCHAR`类型的列会被当作字符串处理,而不是...

    探究MySQL中varchar的定义长度

    因此,`VARCHAR`的定义长度在这些字符集下会有不同的含义。 总之,`VARCHAR`的定义长度是以字节为单位的,实际能存储的字符数量取决于所使用的字符集。在设计数据库时,不仅要考虑列的最大字符数,还要考虑到字符集...

    浅析Oracle中char和varchar2的区别 电脑资料.docx

    首先,char 是定长的字符串类型,例如 char(10) 表示这个字段的长度是 10 个字符,如果我们存储的数据少于 10 个字符,剩下的空间将被空格填充,而 varchar2 则不同,varchar2(10) 只是表示这个字段的最大长度是 10 ...

    MySQL数据类型varchar详解

    MySQL中的`VARCHAR`数据类型是用于存储可变长度的字符串数据的,它的主要优势在于空间效率,因为它只存储实际输入的字符数量,不像`CHAR`数据类型会预留固定长度的空间。下面将详细介绍`VARCHAR`的逻辑意义、最大...

    python遇到sql2005 varchar(4000) varchar(MAX)

    在SQL Server中,varchar数据类型用于存储可变长度的非Unicode文本数据。varchar(4000)表示最大能存储4000个字符,而varchar(MAX)则可以存储最多2^31-1个字符,即大约2GB的数据。 在实际应用中,当Python需要与SQL ...

    MySQL中VARCHAR与CHAR格式数据的区别

    在MySQL数据库中,CHAR和VARCHAR是两种常见的字符串数据类型,它们在存储和处理方式上有着显著的区别,这对于数据库设计和性能优化至关重要。 首先,CHAR是一种固定长度的数据类型。这意味着无论你存储的实际数据有...

    MySQL数据库varchar的限制规则说明

    在MySQL数据库中,`VARCHAR`是一种非常常用的可变长度字符串数据类型,用于存储较短的文本数据。它的优点在于空间利用率高,因为它只存储实际的数据长度,而不是固定长度的存储空间。然而,`VARCHAR`类型并非没有...

Global site tag (gtag.js) - Google Analytics