首頁 > 資料庫 > mysql教程 > php+mysql如何查詢日期內的數據

php+mysql如何查詢日期內的數據

WBOY
發布: 2023-05-30 20:13:16
轉載
971 人瀏覽過

第一步是建立資料庫表並插入一些資料。我們來建立一張表,名為“orders”,包括以下欄位:

  • id: 自增ID

  • date: 下單日期

  • amount: 訂單金額

#使用下列SQL語句建立表格:

CREATE TABLE orders (
id INT(11) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
date DATE,
amount DECIMAL(10,2)
);
登入後複製

接下來,我們可以插入一些測試數據,使用以下SQL語句:

INSERT INTO orders (date, amount) VALUES
('2021-01-01', 100),
('2021-01-02', 50),
('2021-01-03', 200),
('2021-01-04', 150),
('2021-01-05', 75);
登入後複製

現在我們有一個包含訂單資料的表。

下一步是寫PHP程式碼來查詢日期區間內的資料。我們將新建一個檔案命名為“search.php”,然後使用下面的程式碼:

<?php
//连接数据库,以下为参数示例
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "database_name";
$conn = new mysqli($servername, $username, $password, $dbname);

//检查是否连接成功
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

//检查搜索日期的输入
if (isset($_POST[&#39;from_date&#39;]) && isset($_POST[&#39;to_date&#39;])) {
    //将输入的日期格式化为MySQL日期格式
    $from_date = date(&#39;Y-m-d&#39;, strtotime($_POST[&#39;from_date&#39;]));
    $to_date = date(&#39;Y-m-d&#39;, strtotime($_POST[&#39;to_date&#39;]));

    //查询日期区间内的订单数据
    $sql = "SELECT * FROM orders WHERE date >= &#39;$from_date&#39; AND date <= &#39;$to_date&#39;";
    $result = $conn->query($sql);

    //输出查询结果
    if ($result->num_rows > 0) {
        echo "<table><tr><th>ID</th><th>Date</th><th>Amount</th></tr>";
        while($row = $result->fetch_assoc()) {
            echo "<tr><td>".$row["id"]."</td><td>".$row["date"]."</td><td>".$row["amount"]."</td></tr>";
        }
        echo "</table>";
    } else {
        echo "0 results";
    }
}

//关闭连接
$conn->close();
?>
登入後複製

這段程式碼連接到資料庫,然後檢查使用者輸入的搜尋日期範圍。如果輸入了日期範圍,腳本會將輸入的日期格式化為MySQL日期格式,然後查詢訂單數據,以表格的形式輸出結果。如果沒有結果,將輸出“0 results”。

現在,我們需要建立接收使用者輸入的HTML表單,以下是「search.php」檔案的完整程式碼:

<!DOCTYPE html>
<html>
<head>
    <title>Search Orders By Date Range</title>
</head>
<body>
    <h2>Search Orders By Date Range</h2>
    <form method="POST" action="search.php">
        From: <input type="text" name="from_date" placeholder="YYYY-MM-DD">
        To: <input type="text" name="to_date" placeholder="YYYY-MM-DD">
        <input type="submit" value="Search">
    </form>
    <?php include &#39;search.php&#39; ?>
</body>
</html>
登入後複製

這個HTML檔案建立了一個表單,讓使用者輸入起始和結束日期。我們將使用POST方法提交表單到同一頁面,然後將上述剛剛建立的PHP程式碼包含進去。

現在,我們可以在瀏覽器中開啟這個文件,並使用表單輸入日期範圍來搜尋訂單資料。結果將在表格中顯示。

以上是php+mysql如何查詢日期內的數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板