mysql 查询中文 like不准的问题
2009-07-29 17:08
411 查看
在做MySQL的Like查询是发现中文搜索总是不争取,从网上找到了几个解决方法,大家可以看看:
方法一:
解决方法是对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10)"改成"name
char(10)binary"。
方法二:
如果你使用源码编译MySQL,可以编译MySQL时使用--with--charset=gbk
参数,这样MySQL就会直接支持中文查找和排序了。
方法三:
可以使用 Mysql 的 locate 函数来判断。以上述问题为例,使用方法为:
SELECT * FROM table WHERE locate(field,'李') > 0;
方法四:
把您的Select语句改成这样,SELECT * FROM TABLE WHERE FIELDS LIKE BINARY '%FIND%'即可
问题出现的原因是:
在MySQL中,进行中文排序和查找的时候,对汉字的排序和查找结果是错误的。这种情况在MySQL的很多版本中都存在。如果这个问题不解决,那么MySQL将无法实际处理中文。
MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象
我用的第三个办法 select * from table where locate(`字段名`,'关键字')>0;
LOCATE(substr,str)
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在
str 中不存在,返回值为 0:
mysql> SELECT LOCATE(’bar’, ‘foobarbar’);
-> 4
方法一:
解决方法是对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10)"改成"name
char(10)binary"。
方法二:
如果你使用源码编译MySQL,可以编译MySQL时使用--with--charset=gbk
参数,这样MySQL就会直接支持中文查找和排序了。
方法三:
可以使用 Mysql 的 locate 函数来判断。以上述问题为例,使用方法为:
SELECT * FROM table WHERE locate(field,'李') > 0;
方法四:
把您的Select语句改成这样,SELECT * FROM TABLE WHERE FIELDS LIKE BINARY '%FIND%'即可
问题出现的原因是:
在MySQL中,进行中文排序和查找的时候,对汉字的排序和查找结果是错误的。这种情况在MySQL的很多版本中都存在。如果这个问题不解决,那么MySQL将无法实际处理中文。
MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象
我用的第三个办法 select * from table where locate(`字段名`,'关键字')>0;
LOCATE(substr,str)
返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在
str 中不存在,返回值为 0:
mysql> SELECT LOCATE(’bar’, ‘foobarbar’);
-> 4
相关文章推荐
- 有关ssh连接linux服务器后在mysql查询后输出中文结果乱码的的问题
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- python查询mysql中文乱码问题
- MySql 查询语句中包含中文,日志打印为乱码问题解决
- Hql语句模糊查询‘like’与传递中文乱码问题
- 编程查询mysql中文乱码问题
- MySQL的Like查询问题
- Hibernate3的Like用法,解决中文查询问题
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- 使用模糊查询Like时中文匹配下划线通配符无效的问题
- java查询mysql中文问题
- mysql默认编码设置成gbk,解决dos下查询中文乱码的问题!
- mysql 查询的时候处理中文汉字按照字母排序问题
- Hql语句模糊查询‘like’与中文问题
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- 连接mysql查询时的中文编码问题
- JDBC从mysql查询中文乱码问题
- mysql查找语句中包含中文字符时查询失效的问题及解决方法
- mysql在dos下查询怎么正确显示中文的问题
- python查询mysql中文乱码问题