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自己定义的长度,查了一圈发现了真相:

    原来Mysql中varchar(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;
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值