Maison >développement back-end >Problème PHP >Comment interroger des données dans la date avec php+mysql

Comment interroger des données dans la date avec php+mysql

PHPz
PHPzoriginal
2023-03-23 16:53:181560parcourir

PHP et MySQL sont l'une des technologies les plus couramment utilisées pour le développement Web. En développement, il est souvent nécessaire d’interroger des données dans un intervalle de temps spécifique. Dans cet article, nous expliquerons comment utiliser PHP et MySQL pour interroger des données dans une plage de dates.

La première étape consiste à créer une table de base de données et à insérer des données. Créons une table nommée "orders", comprenant les champs suivants :

  • id : identifiant d'auto-incrémentation
  • date : date de commande
  • amount : montant de la commande

Utilisez l'instruction SQL suivante pour créer la table :

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

Ensuite, nous pouvons insérer des données de test, en utilisant l'instruction SQL suivante :

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);

Nous avons maintenant une table contenant les données de la commande.

L'étape suivante consiste à écrire du code PHP pour interroger les données dans la plage de dates. Nous allons créer un fichier appelé « search.php » et utiliser le code suivant :

<?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();
?>

Ce code se connecte à la base de données puis vérifie la plage de dates de recherche saisie par l'utilisateur. Si une plage de dates est saisie, le script formatera la date saisie au format de date MySQL, puis interrogera les données de commande et affichera les résultats dans un tableau. S'il n'y a aucun résultat, « 0 résultat » sera affiché.

Maintenant, nous devons créer le formulaire HTML qui accepte les saisies de l'utilisateur, voici le code complet du fichier "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>

Ce fichier HTML crée un formulaire qui permet à l'utilisateur de saisir une date de début et de fin . Le formulaire sera soumis sur la même page en utilisant la méthode POST, suivi du code PHP que nous venons de créer ci-dessus.

Nous pouvons maintenant ouvrir ce fichier dans un navigateur et utiliser le formulaire pour saisir une plage de dates afin de rechercher les données de commande. Les résultats seront affichés dans un tableau.

Voici comment utiliser PHP et MySQL pour interroger des données dans une plage de dates. Cette approche peut être appliquée à toute tâche de développement Web nécessitant la recherche de données dans un intervalle de temps donné.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn