database.sarang.net
UserID
Passwd
Database
DBMS
MySQL
PostgreSQL
Firebird
ㆍOracle
Informix
Sybase
MS-SQL
DB2
Cache
CUBRID
LDAP
ALTIBASE
Tibero
DB 문서들
스터디
Community
공지사항
자유게시판
구인|구직
DSN 갤러리
도움주신분들
Admin
운영게시판
최근게시물
Oracle Q&A 39215 게시물 읽기
No. 39215
GROUP BY 결과에 대한 질문입니다.
작성자
그룹바이
작성일
2012-01-09 16:38ⓒ
2012-01-09 16:38ⓜ
조회수
4,084

안녕하세요.

연도별 조건을 걸고 group by를 하게 되면 내용이 있는 년도만 출력이 되는데 범위안에 내용이 없더라도 선택한 범위가 0으로 출력되게 할 수 있을까요?

예를 들자면

검색범위는 2008~2011년 이라 하고 데이터는 2009, 2010년 데이터만 있을 경우 결과는 2009년과 2010년만 출력이 되는데

제가 원하는것은 2008년은 해당 컬럼에 대한 데이터가 0으로 채워지게 해서 나오게 하고 있습니다.

 

2008_____0______0_______0

2009_____9______1_______8

2010_____5______7_______-2

2011_____0______0_______0

이런 형식으로 말이지요.

예를 들어 설명해주시면 감사하겠습니다.

이 글에 대한 댓글이 총 2건 있습니다.

 

 

 

with t as (

select to_date('2011-01-01','YYYY-MM-DD') DD, 1  as val from dual union all

select to_date('2011-02-01','YYYY-MM-DD') DD, 1  as val from dual union all

select to_date('2011-03-01','YYYY-MM-DD') DD, 1  as val from dual union all

select to_date('2010-01-01','YYYY-MM-DD') DD, 1  as val from dual union all

select to_date('2010-02-01','YYYY-MM-DD') DD, 1  as val from dual union all

select to_date('2008-01-01','YYYY-MM-DD') DD, 1  as val from dual

)

select to_char(dumy.dd, 'YYYY')as dd,

       sum(nvl(t.val, 0)) as val

from   t,

       (select ADD_MONTHS(to_date('2005', 'YYYY'), 12*level) dd

          from   dual 

          connect by level <= 10) dumy

where  t.dd(+) = dumy.dd

group by to_char(dumy.dd,'YYYY')

 

박광일(tohappy)님이 2012-01-09 18:39에 작성한 댓글입니다.

답변 감사합니다.

결국 기준년도가 있는 테이블과 아웃터 조인을 하면 되는군요 !

감사합니다~

그룹바이님이 2012-01-09 21:03에 작성한 댓글입니다. Edit
[Top]
No.
제목
작성자
작성일
조회
39219쿼리 질문드려요^^ [1]
김진
2012-01-10
3560
39217이런건 어떻게 구할까요? [3]
김종태
2012-01-10
3948
39216in 과 반대되는 구문이 있을까요? [2]
sql어렵다
2012-01-10
3233
39215GROUP BY 결과에 대한 질문입니다. [2]
그룹바이
2012-01-09
4084
39214count 질문입니다. [2]
봉달이
2012-01-09
4107
39213중복되는 문자열은 DB 어떻게 저장될까요? [1]
아크로
2012-01-09
3464
39212sqlplus에서 컬럼 폭 조절에 관해서 [2]
깽즈야
2012-01-07
5205
Valid XHTML 1.0!
All about the DATABASE... Copyleft 1999-2024 DSN, All rights reserved.
작업시간: 0.017초, 이곳 서비스는
	PostgreSQL v16.2로 자료를 관리합니다