質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
date

dateは、date型や日付に関する関数や処理についてのタグです

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

解決済

2回答

3425閲覧

データベースから取得した日付と今日の日付を比較する方法

emi_ono

総合スコア83

date

dateは、date型や日付に関する関数や処理についてのタグです

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

0クリップ

投稿2021/09/05 08:35

前提・実現したいこと

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)がおかしいのかな?
と考えたのですが、分からなくなってしまいました。
どうぞよろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

最終的にどのようなSQLを投げているのか確認してみれば分かると思うのですけれど。

SQL

1SELECT id, day FROM test1 AND date(day) >= '{$today}' 2 ORDER BY day ASC

投稿2021/09/05 08:53

ishina_yum

総合スコア509

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

emi_ono

2021/09/06 05:42

ishina_yumさん、ありがとうございます! 解決しました。
guest

0

ベストアンサー

このままだと、出来上がるSQL文はSELECT id, day FROM test1 AND date(day) >= '日付'のようになってしまいます。文法的に成り立ちません。

条件を1つしか変動させないならANDWHEREに書き換える、あるいは他にも条件を並べたいなら最初の$sqlWHERE 1 = 1のようなダミー条件を入れておく、などの必要があります。

投稿2021/09/05 08:42

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

emi_ono

2021/09/06 05:32

maisumakunさん、ありがとうございます! 「AND」を「WHERE」に変更すると解決しました。 ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問