免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1494 | 回复: 2
打印 上一主题 下一主题

Mysql的一个查询的异常?【问题已经解决,谢谢大家指点】 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-04-10 11:26 |只看该作者 |倒序浏览
Mysql version: 4.0.12
建立了一个简单表:
CREATE TABLE test(
  bid int(11) NOT NULL auto_increment,
  name varchar(50) NOT NULL default '',
  PRIMARY KEY  (bid)
)
插入三条数据:
insert into test values ('','刘亚军');
insert into test values ('','刘亚君');
insert into test values ('','刘亚均');
然后执行查询:
select * from test where name='刘亚军';
发现“刘亚君”也出现在结果中了,同样查询“刘亚君”也能查到“刘亚军”。
也就是说我的mysql数据库中“军”和“君”是不分的。
同样测试了4.1.12版本,结果也是一样。
不知道该如何解释和避免这一结果,请各位多多指教。

[ 本帖最后由 diedream0000 于 2006-4-10 12:19 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-04-10 11:48 |只看该作者
老问题了,where 后面加上 binary

论坛徽章:
0
3 [报告]
发表于 2006-04-10 12:09 |只看该作者

回复 2楼 rardge 的帖子

谢谢rardge 指点。
加了binary问题确实解决了。原来这真是老问题了,我真是后知后觉丫。
---
为巩固一下,转一篇相关文章如下:
------------------------------------------
为什么我的 Mysql 不支持中文查询?
链接:http://www.phpe.net/faq/66.shtml
Q:

我在写一个查询条件时的问题如下:
如我想写一个字段中包含“李”字的所有记录
$str="李";
select * from table where field like '%$str%' ;
显示的记录中除了包含”李”字的记录,还有不包含“李”字的记录。为什么?



A:

在MySQL中,进行中文排序和查找的时候,对汉字的排序和查找结果是错误的。这种情况在MySQL的很多版本中都存在。如果这个问题不解决,那么MySQL将无法实际处理中文。

  出现这个问题的原因是:MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象。

方法一:

解决方法是对于包含中文的字段加上"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%'即可!

[ 本帖最后由 diedream0000 于 2006-4-10 12:15 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP