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

先说结论

中文字符截取,使用 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 还是 "测试社区";
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值