
postgreSQLの構文内で今月の頭(1日)や先月の頭(1日)や先月の末日を変数として出力する方法を教えてください。
※データのテーブルは添付参照
もちろん日付を意図して指定しての構文はできるのですが、汎用的に作成したくご相談させてください。
①今月の頭の算出はあまり浮かんでいないです。
②先月の頭は今月の頭-1(月の方を引く) 例 2021-09-01.000 -1ヶ月 = 2021-08-01.000
③先月の末は今月の頭-1(月の方を引く) 例 2021-09-01.000 -1秒 = 2021-08-30.xxx
また、ここで得られた構文をselectの中に埋め込みたいです。
select
*
from
eample_table
where
date >= '②'
and
date <= '③';
このような構文を作ることは可能でしょうか。
以上、よろしくお願いいたします。

A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
マニュアル、読んだことありますか?
https://www.postgresql.jp/document/12/html/index …
9.9. 日付/時刻関数と演算子
https://www.postgresql.jp/document/12/html/funct …
に日付関連の演算や関数がサンプルと一緒に載っています。
これを一通り読むだけで、複数のアイディアが思い浮ぶのではないでしょうか?
たとえば
ある日付を含む月の最初の日を求める方法
・「ある日付」 - (「ある日付の『日』」-1)日 を計算する
・(「ある日付」の『年』)年(「ある日付」の『月』)月1日 を作る
・「ある日付」を『月』で切り捨てる
判定の方も、「8/31 23:59:59以前」だと「8/31 23:59:59.1」が範囲外になります。
この場合は
・時刻込みのdate列ではなく、そこから日付部分だけを抜き出す
・「最終日以前」ではなく「次月の1日0時0分より前」にする
等の対策があります。
また
「列dateを含む月の最初の日」= 指定月の最初の日
とすれば範囲で考える必要がなくなります。
「列dateの『年』」= 指定年 and 「列dateの『月』」= 指定月
というやり方もあります。
どの方法がいいかは、最終的に何がしたいかにもよるので、いろいろ考えてみましょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) vba 等間隔の列に対しての計算 6 2022/05/17 20:15
- Excel(エクセル) 【マクロ】ファイル名の日付によって、保管するフォルダを、自動選択したい 4 2023/08/16 11:24
- Excel(エクセル) エクセルについて教えてください。 1 2023/03/03 08:38
- Visual Basic(VBA) VBA 連続する名前ごとに集計 3 2022/05/21 18:24
- 雇用保険 育児給付金について 1 2022/08/12 10:51
- Excel(エクセル) エクセルVBA オートフィルタでの絞り込みと並び替えについて 1 2023/07/08 13:08
- Excel(エクセル) ②Excel 簡単にシートコピーしたら前日の残高と日付を変更させたい→マクロの記録でエラーが出ます 8 2022/07/16 20:40
- Excel(エクセル) エクセル関数について 2 2022/04/13 18:25
- その他(Microsoft Office) 従業員増減対応で当番種類の増減対応な当番表 21 2022/07/19 07:30
- Excel(エクセル) Excel 売上管理シートに入力した売上データを、日報に自動反映させたいと考えています。 売上管理シ 3 2023/04/29 18:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
列が存在しないと言われる
-
INSERTできるレコード数を制限...
-
長いSQL文を実行するには?
-
alter tableすると、処理が止ま...
-
0の除算
-
INSERTできない
-
リストを出力する際にSQLでデー...
-
constraint と index の違い
-
SQLite:項目が存在しない場合の...
-
Excel 2019 のピボットテーブル...
-
「直需」の意味を教えてください
-
Access テキスト型に対する指定...
-
Accessでテーブル名やクエリ名...
-
Oracle 2つのDate型の値の差を...
-
エクセルVBAで5行目からオート...
-
Access2021 「ISNULL関数には引...
-
テーブルの存在チェックについて
-
accessのレポートで元になるテ...
-
Accessクエリーで両方のテーブ...
-
ORACLEでLONG項目からCHAR項目...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
列が存在しないと言われる
-
alter tableすると、処理が止ま...
-
長いSQL文を実行するには?
-
DBから日付順に指定件数の削除...
-
PostgreSQLで表結合+DELETEしたい
-
INSERTできるレコード数を制限...
-
COPY時のtimestamp型について
-
0の除算
-
■一番最初に値が入っている(Nul...
-
constraint と index の違い
-
特定の位置が特定の範囲に含ま...
-
INSERTできない
-
SQLで特定データがNULLなら別デ...
-
SQLite:項目が存在しない場合の...
-
powergres(postgres)にalter文...
-
postgreSQLの日付を変数にする...
-
インデックスの削除と、インデ...
-
リストを出力する際にSQLでデー...
-
DB2 「既存カラムへのnot null...
-
CREATE INDEXはどういう時に使...
おすすめ情報