2008年8月11日月曜日

SQL 日付計算、曜日計算、月末日計算、時間計算、期間計算、日付抽出

■システム日付、システム時間

・Oracle のサーバ日付を得るには、次のようにする。
(現在日付取得、現在時刻取得)

select sysdate from dual;

select to_char(
sysdate,
'yyyy.mm.dd hh24:mi:ss'
)
from dual
;

select to_char(
sysdate,
'yyyy.mm.dd'
)
from dual
;

select to_char(
sysdate,
'hh24:mi:ss'
)
from dual
;

** Access では、Now() を使用する。

■年の演算(年加算、年減算)

・date 型、または、to_date() で date 型にしたものに対して、年の演算を
行うには、次のようにする。
add_months では、12 ヶ月が 1 年となる。

jcdt date;

jcdt := add_months(jcdt, 12 * 1); -- 1 年加算
jcdt := add_months(jcdt, 12 * -1); -- 1 年減算

select add_months(sysdate, 12 * 1) from dual;

■月の演算(月加算、月減算)

・add_months を使用すると、12 月に 1 ヶ月加算すると翌年の 1 月になる。

jcdt date;

jcdt := add_months(jcdt, 1); -- 1 ヶ月加算
jcdt := add_months(jcdt, -1); -- 1 ヶ月減算

select add_months(sysdate, 1) from dual;

** Access では、
dateadd('m', 1, jcdt)
dateadd('m', 1, now())
を使用する。

■曜日の演算(曜日計算)

・前の週を計算するには、-7 すれば良い。

jcdt date;

jcdt := next_day(jcdt, '月'); -- 次の月曜計算
jcdt := next_day(jcdt, '金'); -- 次の金曜計算
jcdt := next_day(jcdt, '月') - 7; -- 前の月曜計算

select next_day(sysdate, '月') from dual;
select next_day(sysdate, '月') - 7 from dual;

■週の演算(週加算、週減算)

・7 日を加減算すれば、週の計算となる。

jcdt date;

jcdt := jcdt + 1 * 7; -- 1 週加算
jcdt := jcdt - 1 * 7; -- 1 週減算

select sysdate + 1 * 7 from dual;

■月末日の演算

・月末日を求めるには、次のようにする。

jcdt date;

jcdt := last_day(jcdt); -- 月末日

select last_day(sysdate) from dual;

■日の演算(日加算、日減算)

・うるう年や大の月、小の月も考えなくて良い。

jcdt date;

jcdt := jcdt + 1; -- 1 日加算(翌日)
jcdt := jcdt - 1; -- 1 日減算(前日)

select sysdate + 1 from dual;

■日の 0 時

・date 型は、整数部で日を管理しているので、切り捨てれば 0 時となる。

jcdt date;

jcdt := trunc(jcdt); -- jcdt 日の 0 時

select trunc(sysdate) from dual;

select to_char(
trunc(sysdate),
'yyyy.mm.dd hh24:mi:ss'
)
from dual
;

■時間の演算(時間加算、時間減算)

・date 型、小数部で時間を管理している。

jcdt date;

jcdt := jcdt + 1 / 24; -- 1 時間加算
jcdt := jcdt - 1 / 24; -- 1 時間減算

select sysdate + 1 / 24 from dual;

select to_char(
sysdate + 1 / 24,
'yyyy.mm.dd hh24:mi:ss'
)
from dual
;

■分の演算(分加算、分減算)

・date 型、小数部で時間を管理しているので、24 * 60 = 1440 が分の単位と
なる。

jcdt date;

jcdt := jcdt + 1 / 1440; -- 1 分加算
jcdt := jcdt - 1 / 1440; -- 1 分減算

select sysdate + 1 / 1440 from dual;

select to_char(
sysdate + 1 / 1440,
'yyyy.mm.dd hh24:mi:ss'
)
from dual
;

■秒の演算(秒加算、秒減算)

・date 型、小数部で時間を管理しているので、1440 * 60 = 86400 が秒の
単位となる。

jcdt date;

jcdt := jcdt + 1 / 86400; -- 1 秒加算
jcdt := jcdt - 1 / 86400; -- 1 秒減算

select sysdate + 1 / 86400 from dual;

select to_char(
sysdate + 1 / 86400,
'yyyy.mm.dd hh24:mi:ss'
)
from dual
;

■日付間隔、時間間隔、期間計算、時間計算

・勤続年数や勤務時間など日付や時間の間隔を計算するには、次のようにする。
月が整数部で、日以降が小数部で返る。(経過日数、期間内日数)

jcdt date;
mm number;

mm := months_between(sysdate, jcdt); -- SYSDATE と jcdt の期間

select months_between(
sysdate,
to_date('2001.10.18 21:00:00', 'yyyy.mm.dd hh24:mi:ss')
) from dual;

・12 で割れば、年数が得られる。(経過年数計算、勤続年数計算、年齢計算)
年に切り捨てるには trunc を使用すれば良い。

select months_between(
sysdate,
to_date('1999.10.18 21:00:00', 'yyyy.mm.dd hh24:mi:ss')
) / 12
from dual;

select trunc(months_between(
sysdate,
to_date('1999.10.18 21:00:00', 'yyyy.mm.dd hh24:mi:ss')
) / 12)
from dual;

■日付抽出、日付比較、日付判定、時間抽出、時間比較、時間判定

・日付の範囲や時間の範囲でレコードを抽出するには、次のようにする。
日付に索引が付けてあるかにもよるが、一般的にも like より、日付として
の抽出の方が高速と思う。
(Date 型比較、日付型比較、日付大小比較、日付範囲指定)
(日付データ抽出、日付検索、期間指定、期間範囲、期間集計、期間検索)

select * from テーブル名
where jcdt between
to_date('2001.10.18 21:00:00', 'yyyy.mm.dd hh24:mi:ss')
and
to_date('2001.10.31 23:59:59', 'yyyy.mm.dd hh24:mi:ss')
;

select * from テーブル名
where jcdt > sysdate
;

select * from テーブル名
where jcdt >
to_date('2001.10.18 21:00:00', 'yyyy.mm.dd hh24:mi:ss')
;

select * from テーブル名
where to_char(jcdt, 'yyyy.mm.dd hh24:mi:ss') like '2001%'
;

--------------------------------
株式会社ノアテック
www.noah-tec.com

BRANDay宝爱伊-二手奢侈品店


ブランドアイ
ブランドアイ