我是 PHP 和 MySQL 的新手。我正在尝试制作一个简单的搜索表单,我想使用它来根据表单中输入的输入文本显示数据库中的结果。 我的代码是这样的:
表单.php
<!DOCTYPE html>
<html lang="en">
<html>
<head>
<title>test</title>
</head>
<body>
<form action="search.php" method="GET" id="form">
Name: <input type="text" name="name" >
Age:<input type="text" name="age">
Search<input type="submit" name="submit" id="Search" Value="Search">
</form>
</body>
</html>
连接.php
<?php
$connect = mysql_connect('localhost','$user','$password');
if(!$connect){
die('Could not connect'.mysql_error() );
}
$db_selected = mysql_select_db('test');
if(!$db_selected){
die('wrong'.mysql_error() );
}
?>
搜索.php
<?php
include("includes/connect.php");
$name=$_GET['name'];
echo $name;
$query = "SELECT * FROM `cats` WHERE name='\$name'";
$results= mysql_query($query);
if (!empty($results)){
echo "query successful" ;
exit;
}
$row=mysql_fetch_assoc($results);
echo "Age:".$row['age'];
echo "Name:".$row['name'];
?>
echo $names
正确输出结果,echo "query successful"
也是如此。
然而
echo "Age:".$row['age'];
echo "Name:".$row['name'];
只有 echo 的字符串部分,查询似乎没有获取任何结果。
我尝试将 mysql_fetch_asso
c 更改为 mysql_fetch_array
,但它也没有做任何事情。谁能告诉我我在这里做错了什么。我的数据库表有两列和两行。
最佳答案
您通过 \$
转义了变量中的 $
。
尝试:
$query = "SELECT * FROM `cats` WHERE name='$name'";
编辑
来自下面的讨论。
undefined index
的问题在于您正在使用 $row['age']
而实际上,数据库中的列名是 年龄
。因此,在引用该项目时必须使用 $row['Age']
。 name
也是如此。
关于php - 在 where 子句中使用 php 变量时,MySQL 查询不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15097762/