MySQL中修理特殊不可见uft8字符 |
发布时间: 2012/9/24 17:04:39 |
工作中有一个中文字库表,是前辈从其他地方导入的。最近使用的时候发现有些词,比如“清白”,明明只有两个字,却只能用LIKE ‘%清白%’查出,直接=’清白’找不到。 第一反应,前后可能有空格。于是在PHPMyadmin中用MySQL的trim函数过滤了一下 update 字库 set Vocabulary = trim(Vocabulary)但返回的affected rows数居然是0-
select hex('清白'), hex(Vocabulary), Vocabulary from 字库 where Vocabulary like '%清白%'这下一眼就看出正常字符串前多了个hex为“EFBBBF”的字符,将这个十六进制数扔到windows自带的计算器中换成十进制为15711167,真凶确定,删之: update 字库 set Vocabulary = REPLACE(Vocabulary, char(15711167),'')affected rows居然有3000多,怪不得感觉老有些常用词检索不出来呢…… 保险起见,再用了一次trim update 字库 set Vocabulary = trim(Vocabulary)又冒出3个affected rows。 本文出自:亿恩科技【www.enkj.com】 |