日付型のフォーマットにスラッシュを使ってはいけません(文字コードによって値が変わる)
MySQLで日付型(date型)のフォーマットは『2014/07/26』のようなスラッシュではなく、『2014-07-26』のようにハイフンを使います。
スラッシュでも場合によっては動作しますが、
UTF8で指定されたテーブルをSJISなど別の言語で日付抽出するときなどに値が変わります。
場合によっては正しい値が出てしまうのが怖いところです。
[参考記事] 文字コードを指定する方法
[参考記事] PHPでMySQLの文字コードを指定する方法
[参考記事] MySQLでdatetime型(日時)を日付で抽出するSQLの速度比較
次のサンプルはUTF-8にセットされたテーブルでの例です。
『2014-01-01』以降の日付抽出で217件のレコードが抽出されます。
mysql> SELECT count(*) FROM `sample_table` WHERE `sample_time` >= '2014-01-01'; +----------+ | count(*) | +----------+ | 217 | +----------+ 1 row in set (0.00 sec)
これをShift-JISに指定します。
mysql> set names sjis; Query OK, 0 rows affected (0.00 sec)
同じように『2014-01-01』以降の日付抽出で217件のレコードが抽出されます。
mysql> SELECT count(*) FROM `sample_table` WHERE `sample_time` >= '2014-01-01'; +----------+ | count(*) | +----------+ | 217 | +----------+ 1 row in set (0.00 sec)
ところが『2014/01/01』のように指定すると0件になります。
条件によっては異なる件数が抽出されるようです。
ここでの文字セットはShift-JISのままです。
mysql> SELECT count(*) FROM `sample_table` WHERE `sample_time` >= '2014/01/01'; +----------+ | count(*) | +----------+ | 0 | +----------+ 1 row in set (0.00 sec)
これをUTF-8に指定してみると。
mysql> set names utf8; Query OK, 0 rows affected (0.00 sec)
『2014/01/01』のように指定しても正しい値が返ります。
mysql> SELECT count(*) FROM `sample_table` WHERE `sample_time` >= '2014/01/01'; +----------+ | count(*) | +----------+ | 217 | +----------+ 1 row in set (0.00 sec)
正しい書き方をしないと日付型も文字コードに依存します。
ちなみにdatetime型を『2014-07-26』のように単純に比較すると『00:00:00』が補完されます。
`sample_time` = '2014-07-26' ↓と同じ扱い `sample_time` = '2014-07-26 00:00:00'
関連記事
- Seedの実行順(外部キー制約などを先に実行させる方法) Foreign key violation
- EC-CUBE2系で商品を大量にカートに入れると注文情報が抜けたりカートが消えたりする
- yumのius(iuscommunity.org)でエラーが出る場合
- iusリポジトリで公開されているパッケージの一覧
- phpMyAdminでログイン画面を出さずにデータベースに接続する方法
- MySQLやMariaDBは標準ではログローテートされない
- MySQL(MariaDB)をユーザー情報を含めてすべて移行する方法
- 4.0以前と4.1以降のパスワード方式の違い
- CakePHPでカラムを比較してSELECTする方法
- 『Table is marked as crashed and should be repaired』の修復方法
- コマンドやphpMyAdminで複数のデータベースに接続できるユーザーを作成する方法
- phpMyAdminで『information_schema』などを非表示にする方法
- PDO_MYSQLをインストールする方法
- MySQLでdatetime型(日時)を日付で抽出するSQLの速度比較
- データベースを定時バックアップする方法(毎日バックアップする処理)
- MySQL関数のまとめ
- MySQLの処理を停止させる方法
- MySQLサーバに接続できるかどうかを確認する
- 複数のデータベースを切り替える方法(別データベースを使用する)
- MySQLで文字化けを防ぐ方法
- 別テーブルでSELECT JOINしながらUPDATEする方法(SELECTした結果でUPDATEする)
- OpenPNE3のデータベースの設定
- MySQLのログファイル ログの種類と保存先
- 文字コードを指定する方法
- LIMITで件数制限をしつつ、全件数を取得する方法 SQL_CALC_FOUND_ROWS FOUND_ROWS()
- SQL Buddy ブラウザベースのMySQL管理ツール
- Got a packet bigger than 'max_allowed_packet' bytes
- CakePHPのDB接続情報設定
- SQL文で特定の曜日のみ抽出するには
- OpenPNE3のサーバ移行の方法
- EC-CUBEのサーバ移行の方法
- EC-CUBEのバックアップ機能とリストア
- EC-CUBEでMySQLデータベースのデータ取得で文字化けするときの対処法
- symfonyのORマッパ(Propel、Doctrine)
- Ruby on Railsのマイグレーションの型とMySQLの型の対応表
- MySQLでランダムな数字を得る方法
- MySQLでBeep音を消す設定
- Zend_DBのSELECTメソッドのまとめ
- Zend_DBの基本
- MySQLでクエリーをログに記録する方法
- MySQLのインストール
- Zend Frameworkのデータベース接続
- WordPressのインストール
- DB設計を見直してEC-CUBEを高速化する
- WindowsでMySQLを再起動する方法
- レコード挿入時の #1364 - Field doesn't have a default value
- オフセットの後半になると急に遅くなる MySQLの高速化
- Beep音を無効にする
- MySQL Query Browser 本家GUIツール
- CSE(Common SQL Environment) SQL便利ツール
- Symfony PropelでのMySQLの設定方法
- MySQLのソケットエラー
- utf8_general_ci と utf8_unicode_ci の違い
- 文字列型(データ型)のまとめ
- 日付と時刻型(データ型)のまとめ
- 数値型(データ型)のまとめ
- 個体識別情報・UIDの取得方法
- Windows MySQLインストール後の設定
- Windows MySQLのインストール
スポンサーリンク