我是 PHP 和 MySQL 的新手。我正在尝试制作一个简单的搜索表单,我希望使用它根据表单中输入的输入文本显示数据库的结果。
我的代码是这样的:
Form.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'];
?>
The echo $names
输出结果正确,也是如此echo "query successful"
。
但是,那
echo "Age:".$row['age'];
echo "Name:".$row['name'];
仅回显字符串部分,查询似乎没有获取任何结果。
我尝试改变mysql_fetch_asso
c to mysql_fetch_array
,但它也没有做任何事情。谁能告诉我我在这里做错了什么。我的数据库表有两列和两行。
你正在逃避$
在变量中通过这样做\$
.
Try:
$query = "SELECT * FROM `cats` WHERE name='$name'";
EDIT
从下面的讨论来看。
问题与undefined index
是你正在使用的事实$row['age']
实际上,数据库中的列名是Age
。因此你必须使用$row['Age']
当提及该项目时。同样适用于name
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)