Chinaunix

标题: 请教,用mysql_fetch_array查询中文出错 [打印本页]

作者: dldq    时间: 2007-09-07 10:58
标题: 请教,用mysql_fetch_array查询中文出错
查询输入英文和数字都可以得到正确结果,输入中文,按查询按钮出现一下提示
mysql_num_rows(): supplied argument is not a valid MySQL result resource in F:\www\search.php on line 25


代码:
  1. $name=$_POST['name'];
  2. $sql = "SELECT * FROM db_base  WHERE code LIKE '$name%' OR name LIKE '%$name%' ";
  3. $Record = mysql_query($sql);
  4. $row = mysql_fetch_array($Record, MYSQL_BOTH);
复制代码
注:mysql数据库编码是utf8的
连接接数据后也加了
mysql_query("set names utf8");

搞了两天都不知道啥原因,谢谢了

[ 本帖最后由 dldq 于 2007-9-7 11:15 编辑 ]
作者: wildlily980    时间: 2007-09-07 12:29
$Record = mysql_query($sql);
改成
$record=mysql_query($sql) or die("fail");
作者: dldq    时间: 2007-09-08 21:11
谢谢2楼兄弟相助。
不过这样处理,中文也是查询不了
作者: dz902    时间: 2007-09-08 21:29
去 mysql 版问或者会能容易得到解答一些。或者 Google 一下,淡淡地看了一下,也许有解决方案也说不定。

http://www.google.com/search?hl= ... 0%E4%B8%AD%E6%96%87
作者: dancebear    时间: 2007-09-08 22:19
查询之前先把条件addslashes下。
例如:$name=addslashes($name);
$sql = "SELECT * FROM db_base  WHERE code LIKE '$name%' OR name LIKE '%$name%' ";
作者: dldq    时间: 2007-09-25 10:38
谢谢各位兄弟,问题已经解决
作者: cuhou    时间: 2008-02-18 09:57
请问 你最后是怎么解决的呀?急!!!!
作者: cuhou    时间: 2008-02-18 10:24
改为$sql = "SELECT * FROM db_base  WHERE code LIKE BINARY '$name%' OR name LIKE '%$name%' ";即可
,呵呵




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2