我用Php做了一个简单的搜索功能,为什么SQL语句执行失败,求解释
代码分两段:1.index.php<head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8...
代码分两段:1.index.php
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<body>
<form action="search.php" method="POST" name="form1">
<input type="text" name="search">
<input type="submit" name="sub1" value="搜索">
</form>
</body>
</head>
2.Search.php
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<body>
<table>
<?php
$search=$_POST['search'];
echo "查询条件:".$search."</br>";
$con=mysql_connect("localhost", "root", "");
if($con){
echo "连接数据库成功<br>";
};
$sel=mysql_select_db("fookyue");
if($sel){
echo "选择数据成功</br>";
};
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like '%$search%'");
if($res=mysql_query("$sql")){
echo "SQL语句执行成功</br>";
}else{
echo "SQL语句执行失败</br>";
};
$search1=mysql_fetch_array($sql);
echo $search1;
?>
</table>
</body>
</head>
看来看去没什么错误,就是那个SQL语句执行部成功 展开
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<body>
<form action="search.php" method="POST" name="form1">
<input type="text" name="search">
<input type="submit" name="sub1" value="搜索">
</form>
</body>
</head>
2.Search.php
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<body>
<table>
<?php
$search=$_POST['search'];
echo "查询条件:".$search."</br>";
$con=mysql_connect("localhost", "root", "");
if($con){
echo "连接数据库成功<br>";
};
$sel=mysql_select_db("fookyue");
if($sel){
echo "选择数据成功</br>";
};
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like '%$search%'");
if($res=mysql_query("$sql")){
echo "SQL语句执行成功</br>";
}else{
echo "SQL语句执行失败</br>";
};
$search1=mysql_fetch_array($sql);
echo $search1;
?>
</table>
</body>
</head>
看来看去没什么错误,就是那个SQL语句执行部成功 展开
5个回答
展开全部
if语句语法错误
if语句中,如果要对比2个条件相等,就应该用双等号==,如果要跟严格的比对,那么就应该是三等号===,一个等号是赋值,if语句永远都会成立!
例外,mysql_query()函数,执行成功的话,返回的是真,反之,返回的就是假
那么,if语句只需要判断真假即可,而无需进行赋值比对
我把你这段代码
if($res=mysql_query("$sql")){
echo "SQL语句执行成功</br>";
}else{
echo "SQL语句执行失败</br>";
};
修改如下
echo mysql_query($sql) ? 'Sql语句执行成功' : 'Sql语句执行失败';
if语句中,如果要对比2个条件相等,就应该用双等号==,如果要跟严格的比对,那么就应该是三等号===,一个等号是赋值,if语句永远都会成立!
例外,mysql_query()函数,执行成功的话,返回的是真,反之,返回的就是假
那么,if语句只需要判断真假即可,而无需进行赋值比对
我把你这段代码
if($res=mysql_query("$sql")){
echo "SQL语句执行成功</br>";
}else{
echo "SQL语句执行失败</br>";
};
修改如下
echo mysql_query($sql) ? 'Sql语句执行成功' : 'Sql语句执行失败';
展开全部
有报错么?如果没有··试试下面的改动·
$con=mysql_connect("localhost", "root", "");
if($con){
echo "连接数据库成功<br>";
};
mysql_query("SET NAMES utf8"); // 具体更换你的编码
$sel=mysql_select_db("fookyue");
然后你再查找试试··
$con=mysql_connect("localhost", "root", "");
if($con){
echo "连接数据库成功<br>";
};
mysql_query("SET NAMES utf8"); // 具体更换你的编码
$sel=mysql_select_db("fookyue");
然后你再查找试试··
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like '%$search%'");
if($res=mysql_query("$sql")){
echo "SQL语句执行成功</br>";
//你的$sql已经是执行后的结果了,为毛要再$res=mysql_query("$sql") ?
if($res=mysql_query("$sql")){
echo "SQL语句执行成功</br>";
//你的$sql已经是执行后的结果了,为毛要再$res=mysql_query("$sql") ?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like '%$search%'");这一句修改一下,修改成:
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like '%".$search."%'");
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like '%".$search."%'");
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
$sql=mysql_query("SELECT * FROM mcy_sort WHERE name like %“ . $search . ”%“);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询