如何从我的数据库填充的表中搜索

时间:2015-01-15 19:46:11

标签: php mysql ajax

我有一个MySQL数据库表作为用户。

我使用php和ajax填充html表。(工作正常)

但我想搜索特定的数据,也写了一些代码,但没有得到我的错误。

我的index.html

<body>
    <div class="container">
                <h3>Product List</h3>
            <div id="users-grid">               
            </div>
        </div>
</body>
<script>
    function getresult(url) {    
    $.ajax({
        url: url,
        type: "POST",
        success: function(data){ $("#users-grid").html(data);}
       });
    }
    getresult("getresult.php");
</script>

我的getresult.php(用于填充#users-grid)

<?php 
    include 'database.php';
    $pdo = Database::connect();
    $product = "";
    $queryCondition = "";
?>
<form name="frmSearch" method="post" action="index.php">

    <div class="search-box">
    <p>
    <input type="text" placeholder="Product Name" name="product"  value="<?php echo $product; ?>"   />
    <input type="button" name="go" class="btnSearch" value="Search" onclick="getresult('getresult.php')">
    <input type="reset" class="btnSearch" value="Reset" onclick="window.location='index.php'"></p>
    </div>

    <table class="table table-striped table-bordered" class="tablesorter">
        <thead>
            <tr>
            <th>Date</th>
            <th>Product</th>
            <th>Quantity</th>
            <th>Gross Price</th>
            <th>Profit</th>
            </tr>
        </thead>
        <tbody>
            <?php
                $queryCondition = "";
                if(!empty($_POST["product"])) {
                    $queryCondition .= " WHERE product LIKE '" . $_POST["product"] . "%'";
                }
                $orderby = " ORDER BY id desc"; 
                $sql = "SELECT * FROM users " . $queryCondition . $orderby;
                foreach ($pdo->query($sql) as $row) {
                    echo '<tr>';
                    echo '<td>'. $row['date'] . '</td>';
                    echo '<td>'. $row['product'] . '</td>';
                    echo '<td>'. $row['quantity'] . '</td>';
                    echo '<td>'. $row['grossprice'] . '</td>';
                    echo '<td>'. $row['profit'] . '</td>';
                    echo '</tr>';
                }
                Database::disconnect();
            ?>
        </tbody>
    </table>
</form>

谢谢

1 个答案:

答案 0 :(得分:0)

此代码将搜索以搜索查询开头的任何内容

$queryCondition .= " WHERE product LIKE '" . $_POST["product"] . "%'";

我认为您应该将其更改为具有完整搜索功能

$queryCondition .= " WHERE product LIKE '%" . $_POST["product"] . "%'";

当您点击提交按钮时,只有当用户点击按钮时才会触发,但是当用户在文本上输入内容并按回车键时,它将提交您的表单,因此您必须将代码更改为

<form name="frmSearch" method="post" onsubmit="return getresult('getresult.php')">
    <div class="search-box">
        <input type="text" placeholder="Product Name" name="product" value="<?php if(isset($_POST["product"])) echo $_POST["product"]; ?>"   />
        <input type="button" name="go" class="btnSearch" value="Search">
        <input type="reset" class="btnSearch" value="Reset" onclick="window.location='index.php'">
    </div>
</form>

我更改了输入值以显示您的搜索查询。返回部分用于停止页面重新加载

要发送POST数据,您必须将ajax代码更改为

function getresult(url) {   
    $.ajax({
        url: url,
        type: "POST",
        data: {product: $('input[name=product]').val()},
        success: function(data){ $("#users-grid").html(data);}
   });
   return false
}