php - 搜索栏不会返回结果

标签 php html mysql ajax

<分区>

无法弄清楚这里出了什么问题,没有出现错误但没有返回任何内容。搜索栏应该从我的数据库中返回其他用户的名字。

这是 Test.php:

<?php
    session_start();
?>  

<!DOCTYPE html>
<head>
    <script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
    <script type="text/javascript">
        function search(partialSearch){
            $.ajax({
                url:"PHP.php",
                type:"POST",
                data {partialSearch:partialSearch},
                success:function(result){
                    $("#results").html(result);
                }
            });
        };
    </script>
</head>

<body>

    <div class="container">

        <h3>Find Other users</h3>

        <input type="text" name="partialSearch"onkeyup="search(this.value)"/>
        <div id="results"></div>
    </div>

</body>
</html>

这里是PHP.php

<?php

    $servername = "localhost";
    $username = "root";
    $password = "root";
    $dbname = "coursework_db";

    // Create connection
    $conn = new mysqli($servername, $username, $password, $dbname);
    // Check connection
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    } 

    $partialSearch = $_POST['partialSearch'];

    $stmt = $conn->prepare("SELECT username FROM members WHERE username LIKE ? ");
    $stmt->bind_param('s',$partialSearch);
    $stmt->execute();
    $stmt->bind_result($username);
    while ($row = $stmt->fetch()) {
        $searchResults[] = $username;
        echo "<div>".$searchResults."</div>";
    }
?>

这是 SQL 表:

CREATE TABLE members (
memberID int(5) NOT NULL AUTO_INCREMENT,
username VARCHAR(65) NOT NULL UNIQUE,
password VARCHAR(65) NOT NULL,
PRIMARY KEY (memberID)
);

提前感谢您的帮助!

最佳答案

除了缺少的冒号

data {partialSearch:partialSearch},
    ^

应该读作:

data: {partialSearch:partialSearch},

您的 PHP/MySQL 语法已关闭。

你正在声明 $row

while ($row = $stmt->fetch())

但不在任何地方使用它。

但是,这有点不利,因为您不需要那么多代码来开始。

另外,由于您使用的是 LIKE,因此您没有使用正确的语法。

参见手册:http://dev.mysql.com/doc/refman/5.7/en/string-comparison-functions.html

你的代码应该是这样的:

$partialSearch = "%". $_POST['partialSearch'] ."%";
$stmt = $conn->prepare("SELECT username FROM members WHERE username LIKE ? ");

$stmt->bind_param('s',$partialSearch);
$stmt->execute();
$stmt->bind_result($username);

while ($stmt->fetch()) {

    echo $username;

    echo "<div>".$searchResults."</div>";
}

检查控制台和错误后,您就会知道发生了什么或没有发生什么。

JS 控制台会抛出你:

SyntaxError: missing : after property id

如果这仍然对您不起作用,那么您的数据库中很可能有错误。

咨询:

关于php - 搜索栏不会返回结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36636315/

相关文章:

php - 将 INT 绑定(bind)到 PDO 准备好的 LIMIT 和 OFFSET 语句时出现问题

php - 无法输出数据库中数组的所有行

php - 我的学说真的很慢。简单查询,一秒出结果

mysql - 获取记录集上的第二个 Mysql 表列

php - 1265 数据在第 1 行的列在几个值后被截断

php - 创建 JSON 对象并将其发送到 PHP(服务器)

javascript - 使 svg 缩放到全屏大小

html - 如何使用CSS将文本与其阴影分开

带有目标的 HTML 链接

mysql - 如何通过单击 grails 中的按钮(.Groovy Server Pages 页面)从 Mysql 数据库获取表的所有值/行?