>백엔드 개발 >PHP 문제 >php+mysql을 사용하여 날짜 내의 데이터를 쿼리하는 방법

php+mysql을 사용하여 날짜 내의 데이터를 쿼리하는 방법

PHPz
PHPz원래의
2023-03-23 16:53:181557검색

PHP와 MySQL은 웹 개발에 가장 일반적으로 사용되는 기술 중 하나입니다. 개발 중에는 특정 시간 범위 내의 데이터를 쿼리해야 하는 경우가 많습니다. 이 기사에서는 PHP와 MySQL을 사용하여 날짜 범위 내의 데이터를 쿼리하는 방법을 공유합니다.

첫 번째 단계는 데이터베이스 테이블을 만들고 일부 데이터를 삽입하는 것입니다. 다음 필드를 포함하여 "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['from_date']) && isset($_POST['to_date'])) {
    //将输入的日期格式化为MySQL日期格式
    $from_date = date('Y-m-d', strtotime($_POST['from_date']));
    $to_date = date('Y-m-d', strtotime($_POST['to_date']));

    //查询日期区间内的订单数据
    $sql = "SELECT * FROM orders WHERE date >= '$from_date' 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개 결과"가 출력됩니다.

이제 사용자 입력을 허용하는 HTML 양식을 만들어야 합니다. 다음은 "search.php" 파일의 전체 코드입니다.

<!DOCTYPE html>
<html>
<head>
    <title>Search Orders By Date Range</title>
</head>
<body>
    <h1>Search Orders By Date Range</h1>
    <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+mysql을 사용하여 날짜 내의 데이터를 쿼리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.