티스토리 뷰
주말 및 휴일을 제외하고 평일만 가져오는 오라클 쿼리를 만들어 보겠다.
select count(1) from
(
select to_char(sdt+level-1'yyyymmdd') dt, to_char(sdt+level-1'D') D from
(
select trunc(to_date('20190301'),'MM') sdt, last_day(to_date('20190331')) edt from dual
)
connect by level <= edt-sdt+1
) a
,
(
select holi_year||holi_day dt
from holiday
where to_char(to_date(holi_year||holi_day),'yyyymm')=substr('20190301',0,6)
) b
where a.dt=b.dt(+)
and a.d not in ('1','7')
and b.dt is null
끝~
휴일테이블에서 그 달의 휴일 정보를 가져오고 토일,빼고 해당달의 평일 일 수 를 가져온다.
connect by level 에 의해 1일 부터 말일 까지 쫙~ 나온다. 그걸 count를 하니 평일 일수가 나온다.
connect by level 에 대한 상세 정보는 다음 글에~
select count(1) from
(
select to_char(sdt+level-1'yyyymmdd') dt, to_char(sdt+level-1'D') D from
(
select trunc(to_date('20190301'),'MM') sdt, last_day(to_date('20190331')) edt from dual
)
connect by level <= edt-sdt+1
) a
,
(
select holi_year||holi_day dt
from holiday
where to_char(to_date(holi_year||holi_day),'yyyymm')=substr('20190301',0,6)
) b
where a.dt=b.dt(+)
and a.d not in ('1','7')
and b.dt is null
끝~
휴일테이블에서 그 달의 휴일 정보를 가져오고 토일,빼고 해당달의 평일 일 수 를 가져온다.
connect by level 에 의해 1일 부터 말일 까지 쫙~ 나온다. 그걸 count를 하니 평일 일수가 나온다.
connect by level 에 대한 상세 정보는 다음 글에~
'티베로(Tibero) 오라클(Oracle)' 카테고리의 다른 글
ORA-12543: TNS:수신지 호스트에 도달할 수 없습니다 (0) | 2019.04.12 |
---|---|
오라클 connect by level (0) | 2019.03.15 |
오라클 트리구조 정렬 (0) | 2019.01.25 |
오라클 트리구조에서 검색 (0) | 2019.01.25 |
[오라클] having, 중복건중 1건만 남기고 싶을때. rowid를 이용한 중복건 삭제 (0) | 2018.10.10 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 포인터
- 스크래핑
- MySQL
- xe addon
- EC
- 이클립스
- 자바 smtp
- xe애드온
- 파싱
- KG
- webix
- 플러터
- 파이썬
- php
- ocjap
- 인포믹스
- 오라클
- ocpjp
- C
- 문자열
- C언어
- JDBC
- esql
- 프로씨
- proc
- XE
- ocajp
- Python
- XE3
- 자바
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
글 보관함