前提・実現したいこと
PHPで予約システムを作る勉強をしています。
<form>を使ってデータベースに登録したデータ(日付)を「本日」「本日以降」「過去」の日付区分に応じて一覧表示したいのですが、日付の比較が上手くいきません。アドバイを頂きたいです。よろしくお願いします。本日の日付を$today = date('Y-m-d');で取得し
「ownerReserveList.php」にパラメータ「disp」を設置して、値として「today」「after」「before」を用意する。
取得したパラメータの値によって作成するSQLをswitchを使って変化させとうと思っているのですが、
switchをつけると何も表示されなくなってしまいます。
データベースの設計
テーブル名(test1)
id → int(11),AUTO_INCREMENT
day → datetime
該当のソースコード
PHP
1<?php 2require_once('./asset/dbConfig.php'); 3$link = mysqli_connect(DB_SERVER, DB_USER, DB_PASS, DB_NAME); 4if($link == null){ 5 die("接続に失敗しました:". mysqli_connect_error()); 6} 7mysqli_set_charset($link, "utf8"); 8 9$mode = "today"; //指定がない場合は「本日」とする 10 if (isset($_GET["disp"]) == true) { 11 $mode = htmlspecialchars($_GET["disp"]); 12 } 13 14$sql = "SELECT id, day FROM test1"; 15$today = date('Y-m-d');//本日の日付 16 17switch ($mode) { 18 case "after": 19 $modeStr = "(本日以降)"; 20 $sql = $sql . " AND date(day) >= '{$today}' 21 ORDER BY day ASC "; 22 break; 23 case "before": 24 $modeStr = "(過去)"; 25 $sql = $sql. " AND date(day) < '{$today}' 26 ORDER BY day DESC "; 27 break; 28 case "today": 29 $modeStr = "(本日)"; 30 $sql = $sql. " AND date(day) = '{$today}'"; 31 break; 32} 33 34$result = mysqli_query($link, $sql); 35?> 36 37 <div id="contents"> 38 <p>本日:<?php echo $today;?></p> 39 40 <!-- メニュー:開始 --> 41 <nav id="menu"> 42 <li><a href="./ownerReserveList.php?disp=today">本日</a></li> 43 <li><a href="./ownerReserveList.php?disp=after">本日以降</a></li> 44 <li><a href="./ownerReserveList.php?disp=before">過去</a></li> 45 </nav> 46 <!-- コンテンツ:開始 --> 47 <h2>予約管理画面(本日)</h2> 48 <table class="host"> 49 <th>来店日</th> 50 <?php 51 while ($row = mysqli_fetch_array($result, MYSQLI_ASSOC)){ 52 echo "<tr>"; 53 $rdate = date('Y年m月d日', $row['day']); 54 echo "<td>{$rdate}</td>"; 55 echo " <td><a class='submit_a' href='./ownerReserveDelete.php?no={$row['id']}'>削除</a></td>"; 56 echo "</tr>"; 57 } 58 ?> 59 </table> 60 </div> 61 62<?php 63 mysqli_free_result($result); 64 mysqli_close($link); 65?> 66
データベースのdatetime型が違うのかな?やdate(day)がおかしいのかな?
と考えたのですが、分からなくなってしまいました。
どうぞよろしくお願いします。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/09/06 05:42