* DATETIME型/TIMESTAMP型の展開と WHERE句の範囲指定
この記事の直リンクURL: Permlink | この記事が属するカテゴリ: [SQL] [MS SQL Server] [Postgres]
時刻の扱いは データベースエンジンによって異なるので、クエリを作成する前に仕様や挙動を確認しておきたい。
たとえば、 time_column < '2004-08-27' のとき、'2004-08-27' は いつの時点を指すのか。2004-08-27 00:00:00 なのか、 2004-08-27 **:**:** 、つまりランダムなのか。いつもは時分秒まで指定していたので、省略して表記した場合はどうなるか調べておこう。
http://www.microsoft.com/japan/msdn/library/ja/acdata/ac_8_c ...
要するに SQL Server2000 では、00:00:00 になるってことか。
日本PostgreSQLユーザー会: PostgreSQL 7.2.X 付属ドキュメント
http://www.postgresql.jp/document/pg721doc/
7.4 系列の文書も見てみたが、やはり明確な記述は見つけられなかった。
日本PostgreSQLユーザ会: PostgreSQL 7.4.X 付属ドキュメント
http://www.postgresql.jp/document/pg743doc/
まあ、この後やってみればわかるだろう。たぶん SQL Server2000 と同じ結果になると思うけど。
PostgreSQL 7.2.1 用。
結論から言うと、SQL Server2000 と PostgreSQL 7.2 ともに 'YYYY-MM-DD' は 'YYYY-MM-DD 00:00:00:000' に展開される。以下、サンプル。
PostgreSQL 7.2.1 でも SQL Server2000 でも同じ結果になった。以下、Postgres の出力結果。
さっきのテーブルを DROP して CREATE しなおし、8レコード分のテストデータを INSERT する。
INSERT が終わったら SELECT してみる。今度は SQL Server2000 での出力。
予想通り、2004-08-26 は 2004-08-26 00:00:00 に展開された。
イコールを付ければ8/26のレコードもヒット。
Postgres でも同じように動作した。
たとえば、 time_column < '2004-08-27' のとき、'2004-08-27' は いつの時点を指すのか。2004-08-27 00:00:00 なのか、 2004-08-27 **:**:** 、つまりランダムなのか。いつもは時分秒まで指定していたので、省略して表記した場合はどうなるか調べておこう。
- SQL Server2000 の場合
日付時刻データの使用http://www.microsoft.com/japan/msdn/library/ja/acdata/ac_8_c ...
時刻だけまたは日付だけを個別に格納するデータ型はありません。datetime 型または smalldatetime 型の値を設定する場合、時刻だけを指定すると、日付のデフォルト "January 1, 1900" が使用されます。日付だけを指定すると、時刻のデフォルト "12:00AM (深夜)" が使用されます。
要するに SQL Server2000 では、00:00:00 になるってことか。
- PostgreSQL 7.2.1 の場合。
ドキュメントは見つけられなかった。日本PostgreSQLユーザー会: PostgreSQL 7.2.X 付属ドキュメント
http://www.postgresql.jp/document/pg721doc/
7.4 系列の文書も見てみたが、やはり明確な記述は見つけられなかった。
日本PostgreSQLユーザ会: PostgreSQL 7.4.X 付属ドキュメント
http://www.postgresql.jp/document/pg743doc/
まあ、この後やってみればわかるだろう。たぶん SQL Server2000 と同じ結果になると思うけど。
- CREATE TABLE
SQL Server2000 用。CREATE TABLE time_where_test (utime datetime);
PostgreSQL 7.2.1 用。
CREATE TABLE time_where_test (utime timestamp);
- INSERT 時の展開
まずは INSERT のテスト。結論から言うと、SQL Server2000 と PostgreSQL 7.2 ともに 'YYYY-MM-DD' は 'YYYY-MM-DD 00:00:00:000' に展開される。以下、サンプル。
PostgreSQL 7.2.1 でも SQL Server2000 でも同じ結果になった。以下、Postgres の出力結果。
hiroaki=> INSERT INTO time_where_test VALUES ('2004-06-18');
INSERT 93862442 1
hiroaki=> SELECT * FROM time_where_test;
utime
---------------------
2004-06-18 00:00:00
(1 row)
- SELECT 時の展開
今度は SELECT 時のテスト。おそらく INSERT 時と同じように展開されるだろうけど、念のため。さっきのテーブルを DROP して CREATE しなおし、8レコード分のテストデータを INSERT する。
INSERT INTO time_where_test VALUES ('2004-08-09 02:00:00');
INSERT INTO time_where_test VALUES ('2004-08-20 03:00:00');
INSERT INTO time_where_test VALUES ('2004-08-26 00:00:00');
INSERT INTO time_where_test VALUES ('2004-08-26 04:00:00');
INSERT INTO time_where_test VALUES ('2004-08-26 23:59:59');
INSERT INTO time_where_test VALUES ('2004-08-27 00:00:00');
INSERT INTO time_where_test VALUES ('2004-08-27 09:00:00');
INSERT INTO time_where_test VALUES ('2004-08-27 23:59:59');
INSERT が終わったら SELECT してみる。今度は SQL Server2000 での出力。
SELECT * FROM time_where_test WHERE utime < '2004-08-26' ORDER BY utime;
utime
------------------------------------------------------
2004-08-09 02:00:00.000
2004-08-20 03:00:00.000
(2 件処理されました)
予想通り、2004-08-26 は 2004-08-26 00:00:00 に展開された。
イコールを付ければ8/26のレコードもヒット。
SELECT * FROM time_where_test WHERE utime <= '2004-08-26' ORDER BY utime;
utime
------------------------------------------------------
2004-08-09 02:00:00.000
2004-08-20 03:00:00.000
2004-08-26 00:00:00.000
(3 件処理されました)
Postgres でも同じように動作した。
- すべての記事の見出し (全1029件)
 
- 全カテゴリの一覧と記事の数
 - カテゴリごとに記事をまとめ読みできます。記事の表題だけを見たい場合は、すべての記事の見出し (カテゴリ別表示) へ。
- .net (57件)
 - 2ch (19件)
 - amazon (5件)
 - Apache (22件)
 - bash (13件)
 - Bookmarklet (9件)
 - C# (45件)
 - chalow (18件)
 - ChangeLog メモ (20件)
 - coLinux (2件)
 - CSS (5件)
 - Delphi (5件)
 - DVD (6件)
 - Excel (1件)
 - F-ZERO (4件)
 - FF12 (31件)
 - ftp (8件)
 - Google (21件)
 - gpg (7件)
 - HTML (19件)
 - http (19件)
 - IE (10件)
 - IIS (4件)
 - iPod (2件)
 - JavaScript (14件)
 - Linux (63件)
 - MCP (6件)
 - Mozilla (14件)
 - MS SQL Server (30件)
 - MySQL (4件)
 - Namazu (3件)
 - PC (48件)
 - Perl (58件)
 - PHP (2件)
 - Postgres (36件)
 - proftpd (2件)
 - qmail (1件)
 - RFC (4件)
 - RSS (33件)
 - Ruby (15件)
 - samba (3件)
 - sonic64.com (6件)
 - SQL (15件)
 - Squid (3件)
 - ssh (7件)
 - Subversion (3件)
 - unix (31件)
 - VSS (2件)
 - Windows (34件)
 - winny (9件)
 - XML (9件)
 - xyzzy (17件)
 - おいでよ どうぶつの森 (19件)
 - お菓子 (5件)
 - アスキーアート (13件)
 - アニメ (9件)
 - クレジットカード (2件)
 - ゲーム (120件)
 - シェルスクリプト (18件)
 - シレン2 (8件)
 - セキュリティ (9件)
 - ソフトウェア (21件)
 - デザインパターン (2件)
 - ネットワーク (30件)
 - バックアップ (17件)
 - プログラミング (14件)
 - マリオカートDS (3件)
 - メール (26件)
 - メモ (116件)
 - ラーメン (11件)
 - 音楽 (59件)
 - 給油 (3件)
 - 三国志大戦 (13件)
 - 車 (7件)
 - 書斎 (4件)
 - 食 (30件)
 - 買い物 (17件)
 - 簿記 (8件)
 - 本 (32件)
 - 漫画 (9件)
 
 
- 2007-04-23 (Mon)
 - 2007-03-07 (Wed)
 - 2007-02-27 (Tue)
 - 2007-01-17 (Wed)
 - 2007-01-15 (Mon)
 - 2007-01-14 (Sun)
 - 2007-01-08 (Mon)
 - 2006-12-01 (Fri)
 - 2006-11-22 (Wed)
 - 2006-11-20 (Mon)
 - 2006-11-19 (Sun)
 - 2006-09-30 (Sat)
 - 2006-08-29 (Tue)
 - 2006-08-04 (Fri)
 - 2006-07-27 (Thu)
 - 2006-07-23 (Sun)
 - 2006-07-17 (Mon)
 - 2006-07-10 (Mon)
 - 2006-07-06 (Thu)
 - 2006-07-03 (Mon)
 - 2006-06-29 (Thu)
 - 2006-06-28 (Wed)
 - 2006-06-27 (Tue)
 - 2006-06-25 (Sun)
 - 2006-06-19 (Mon)
 - 2006-06-18 (Sun)
 - 2006-06-15 (Thu)
 - 2006-06-11 (Sun)
 - 2006-06-01 (Thu)
 - 2006-05-30 (Tue)
 
- プロファイル
 - 斎藤 宏明。エンジニアです。宇都宮市に住んでいます。
 - リンク
 - RSS
 - スポンサードリンク
 - Powered by
 - 
☆さくらインターネット☆