MySQL 中截取中文字符失效,length方法中文截取问题

本文探讨了在SQL中使用LEFT函数截取包含中文字符的字符串时遇到的问题。通常,length方法计算的是字节长度,而非字符长度,导致在UTF-8编码下,对于中文字符的截取不准确。解决方案是使用char_length函数代替length,因为它以字符为单位计算长度。通过案例分析,解释了为何`left(str, length(str) - 2)`无法正确删除最后两个中文字符,并提出了正确的截取方法`left(str, char_length(str) - 2)`。

先说结论

中文字符截取,使用 char_length(str) 来获取字符串长度
截取方法: left(str, char_length(str) - 2)

问题复现

我的需求是,需要把数据库中的脏数据,最后两个中文字符删掉
在这里插入图片描述
第一个想法就是通过 sql 语句进行截断,所以测试了 LEFT(str, length) 方法
感觉通过 left 可以完美解决我的问题。
在这里插入图片描述
然后,实际找了一条数据去做测试,但是却没法删掉最后的社区两个汉字
在这里插入图片描述
通过查询尝试和查询资料,才发现是 length 方法的问题,换成 char_length 即可
在这里插入图片描述

原因分析

left 方法 在截取 中文字符 “测试社区” 时, length 方法是按照字节为单位,一个汉字在 utf8 下三个字节,在 GBK 下两个字节

 String str = "测试社区";
 // 实际判断后, str 长度是 4
 // left(str, length(str) - 2) length 在 utf8 编码下,长度为 12 字节
 String sub = str.subString(0, 12 - 2);
 // 所以 sub 还是 "测试社区";
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值