免费注册 查看新帖 |

Chinaunix

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

:cry: 请教关于汉字的查询问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-07-31 15:46 |只看该作者 |倒序浏览
我的SQL形式如下:

select *  from table1 where makerName = $maker_Name;
$maker_name 为一个记录汉字的变量,

查询的不到结果,返回总为0

库中明明是有数据的,请问我该如何做呢?

先谢了!

论坛徽章:
0
2 [报告]
发表于 2005-07-31 17:41 |只看该作者

:cry: 请教关于汉字的查询问题

这里没有人回答问题还是对这样的问题不屑回答啊?

自己基本上解决了,偶然的发现,兴奋!!

贴在下面,


  1. A:

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

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

  4. 方法一:

  5. 解决方法是对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10)"改成"name char(10)binary"。

  6. 方法二:

  7.   如果你使用源码编译MySQL,可以编译MySQL时使用--with--charset=gbk 参数,这样MySQL就会直接支持中文查找和排序了。

  8. 方法三:

  9.   可以使用 Mysql 的 locate 函数来判断。以上述问题为例,使用方法为:
  10. SELECT * FROM table WHERE locate(field,'李') >; 0;
  11. 本站使用的就是这种方法,感觉还不错。:P


  12. 方法四:

  13. 把您的Select语句改成这样,SELECT * FROM TABLE WHERE FIELDS LIKE BINARY '%FIND%'即可!

  14. (责任编辑:超越PHP)
复制代码

论坛徽章:
0
3 [报告]
发表于 2005-07-31 17:42 |只看该作者

:cry: 请教关于汉字的查询问题

可是我的程序中还有外键约束的问题,不知道怎么办,痛苦中!!

#1216 - Cannot add or update a child row: a foreign key constraint fails

论坛徽章:
0
4 [报告]
发表于 2005-08-01 09:09 |只看该作者

:cry: 请教关于汉字的查询问题

把外键的属性也一块改了

论坛徽章:
0
5 [报告]
发表于 2005-08-01 10:00 |只看该作者

:cry: 请教关于汉字的查询问题

我没有定义外键啊?!

论坛徽章:
0
6 [报告]
发表于 2005-08-01 13:18 |只看该作者

:cry: 请教关于汉字的查询问题

把建表的sql贴上来看看
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP