データベースのあるデータを、フィールドの"date"の日付け順にwebサイトに表記させるために、
select * table_name where ~ order by date desc
とsql文を書き接続しました。
1月1日から1月30日まではデータが表記されるのですが、1月31日だけ1つのデータも表記されません。
どなたかご教授をお願いいたします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答2件
0
ベストアンサー
あまり詳しくはないのですが、よくあるミスとして、Where句の指定で、1月31日の23時59分59秒まで指定していないから、1月31日の0時扱いになっていて、実質前日までしか見えないとかはありえますね。
投稿2016/01/31 14:08
総合スコア686
0
order by~の問題ではなくtimestamp型やdatetime型の列に対してdate型で比較するとその結果になると思います。'2016-01-31'は'2016-01-31 00:00:00'と解釈されて実行されるはずです。
MySQLなら以下の条件句で比較実行すると違う結果になると思います。
where create_date BETWEEN '2016-01-01' AND '2016-01-31'
where create_date BETWEEN '2016-01-01 00:00:00' AND '2016-01-31 23:59:59'
postgreSQLではBETWEENの替わりに<>で比較しますが同様です。
where create_date>='2016-01-01' AND create_date<'2016-01-31'
where create_date>='2016-01-01 00:00:00' AND create_date<='2016-01-31 23:59:59'
シェルまたはphpMyAdminなどでSQLを実行して比較してみてください。
(動作確認後に日付と列名を書き換えたのでミスがあるかもしれません)
SQL全体またはwhere句も提示していただけるともっと的確な回答が可能になります。
投稿2016/02/01 04:33
総合スコア241
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/02/01 14:07
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/02/01 04:34