
DB初心者で、PostgreSQL V.7.3.2 + PHP を使っています。
T_TIME というテーブルに、
日付を格納したTARGET_DATEと、
時刻を 〃 TARGET_TIMEというフィールドがあります。
このテーブルからタイムスタンプをセレクトしたいと思い、つぎのようなSQL文を
作成しました。
SELECT TO_TIMESTAMP(TARGET_DATE ||' '|| TARGET_TIME, 'YYYY-MM-DD HH24:MI') AS JIKOKU
FROM T_TIME
ところが、この結果は書式化された文字列のため時刻の比較を簡単に行うことができません。
なんとか書式化した形でなく、1970年からの秒数でタイムスタンプを取得したいのですが。
どうすれば良いのでしょうか。
No.1ベストアンサー
- 回答日時:
PostgreSQL 8.0.2 文書 -> 8.5.1.5. 特殊な値より
(以前のドキュメント7.3.0を参照してもこの項目、構文は存在していたので有効です)
入力文字列有効な型説明
epochdate, timestamp1970-01-01 00:00:00+00 (Unixシステム時間におけるゼロ)
今回の場合は、問い合わせの時に若干計算式を記述してやる必要があるようです
select EXTRACT(epoch FROM TARGET_DATE)+
(EXTRACT(HOUR FROM TARGET_TIME)*60+
EXTRACT(MINUTE FROM TARGET_TIME))*60+
(EXTRACT(MILLISECONDS FROM TARGET_TIME)/1000)
from T_TIME;
#問い合わせに対する負荷が高いので、もしかしたら、新しいカラムを用意した方がいいかもしれません
#さらなる情報は参考URL(ドキュメント)を参照して下さい
テストrun:
select EXTRACT(epoch FROM CURRENT_DATE)+
(EXTRACT(HOUR FROM CURRENT_TIME)*60+
EXTRACT(MINUTE FROM CURRENT_TIME))*60+
(EXTRACT(MILLISECONDS FROM CURRENT_TIME)/1000);
クエリー全体 実行時間:10 ms.
データ検索 実行時間:10 ms.
参考URL:http://www.postgresql.jp/document/pg721doc/user/ …
大変ありがとうございます。
お礼が遅れて済みませんでした。半ばあきらめているところでした。
おかげでうまく計算させることができました。
参考URLも見て勉強したいと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
今、見られている記事はコレ!
-
隣の枝がはみ出してきたら切ってもいい?最もやってはいけないことは?
「隣の木が越境してきて困るが、勝手に切ってはいけないと聞くし…」そう思っている方も多いだろう。実は、2023年4月1日に民法が改正され、この「越境枝」のルールが大きく変わった。 教えて!gooでも「境界から出て...
-
弁護士が解説!あなたの声を行政に届ける「パブリックコメント」制度のすべて
社会に対する意見や不満、疑問。それを発信する場所は、SNSやブログ、そしてニュースサイトのコメント欄など多岐にわたる。教えて!gooでも「ヤフコメ民について」というタイトルのトピックがあり、この投稿の通り、...
-
弁護士が語る「合法と違法を分けるオンラインカジノのシンプルな線引き」
「お金を賭けたら違法です」ーーこう答えたのは富士見坂法律事務所の井上義之弁護士。オンラインカジノが違法となるかどうかの基準は、このように非常にシンプルである。しかし2025年にはいって、違法賭博事件が相次...
-
釣りと密漁の違いは?知らなかったでは済まされない?事前にできることは?
知らなかったでは済まされないのが法律の世界であるが、全てを知ってから何かをするには少々手間がかかるし、最悪始めることすらできずに終わってしまうこともあり得る。教えてgooでも「釣りと密漁の境目はどこです...
-
カスハラとクレームの違いは?カスハラの法的責任は?企業がとるべき対応は?
東京都が、客からの迷惑行為などを称した「カスタマーハラスメント」、いわゆる「カスハラ」の防止を目的とした条例を、全国で初めて成立させた。条例に罰則はなく、2025年4月1日から施行される。 この動きは自治体...
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
PostgreSQLの断片化の状況を確...
-
SELECT 文の NULL列は?
-
reindex と update のデッドロック
-
2つのテーブルで引き算 postgres
-
異なるデータベースでのINSERT...
-
MS Access から PostgreSQL へ...
-
SQLでUPSERTを一度に複数行やる...
-
PostgreSQL レコードからアイテ...
-
テーブルに存在しない列をselec...
-
PL/pgSQLを使用してデータ移行...
-
UPDATE文の更新順序について
-
他テーブルの集計結果を別テー...
-
SQL 同じテーブル構造の複数の...
-
PostgreSQL 8.0.2 の ERROR: r...
-
AccessのSQL 部分一致したデー...
-
降順で並び替えて昇順で受け取...
-
「テーブルに座って……」という...
-
Accessでデータシートに同じデ...
-
このISAMでは、リンクテーブル・・
-
DBからタブ区切りのCSVデータを...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SELECT 文の NULL列は?
-
SQLにて指定日付より前、かつ最...
-
テーブルに存在しない列をselec...
-
SQLでUPSERTを一度に複数行やる...
-
単純なselectが遅くなるのです...
-
javaでデータベース上のテーブ...
-
PostgreSQLの断片化の状況を確...
-
テーブルにcsvファイルをインポ...
-
2つのテーブルで引き算 postgres
-
MS Access から PostgreSQL へ...
-
テーブル定義書作成時のIndex付...
-
デットロック回避策(autocommit...
-
PostgreSQL レコードからアイテ...
-
複数テーブルにまたがるmax
-
Postgresのデータ領域の拡張に...
-
テーブルを作ろうとしたら。
-
COPYコマンドによるTEXT取り込...
-
postgreSQL カラムの全ての値を...
-
ワークテーブル(ローカル)か...
-
reindex と update のデッドロック
おすすめ情報