Background Image
조회 수 14092 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

응용 프로그램 개발 시에 내역을 출력하고 중간 중간에 소개를 구하는 양식이 있다고 가정하자.

예시)
===========================================
    지출일자   부서    성명      지출금액
===========================================
   2012-03-01 기술부   홍길동      1,000
   2012-03-02 기술부   홍길동      2,000
   2012-03-03 기술부   홍길동      3,000
   2012-03-04 기술부   홍길동      4,000
   기술부(홍길동)소계                10,000
   2012-03-05 기술부   김개똥      5,000
   2012-03-06 기술부   김개똥      6,000
   2012-03-07 기술부   김개똥      7,000
   기술부(김개똥)소계                18,000
   2012-03-08 기술부   엄길순      8,000
   2012-03-09 기술부   엄길순      9,000
   2012-03-10 기술부   엄길순     10,000
   기술부(엄길순)소계                 27,000
   기술부 소계                              55,000
   2012-03-11 영업부   영업맨     13,000
   2012-03-12 영업부   영업맨     14,000
   2012-03-13 영업부   영업맨     15,000
   영업부(영업맨)소계                 42,000
   2012-03-14 영업부   김영업     16,000
   2012-03-15 영업부   김영업     17,000
   2012-03-16 영업부   김영업     18,000
   영업부(영업맨)소계                 51,000
   영업부 소계                              93,000
   전체 합계                                148,000
===========================================

 

○ 처리방법
  - 1안) 전체 내역을 쿼리해서 이름별, 부서별로 합계를 구하면서 처리하는 방법
  - 2안) 쿼리를 어느정도 사용할 줄 아는 개발자라면 union all을 사용하여 처리하는 방법

○ 처리방법에 대한 검토내용
  - 1안은 이름별, 부서별로 변수를 사용해서 순서에 맞게 처리함으로 약간의 코딩 능력 및 공수가 필요하다.
  - 2안은 부서가 추가되거나, 이름이 추가될때 쿼리를 수정해야 할 수도 있으며,
    옵티마이져가 union all의 각각의 쿼리를 수행함으로 성능이 좋지 않다.
  - 하나의 쿼리로 위의 양식대로 추출할 수 있는 쿼리를 작성한다면, 코딩량도 줄어들 것이고, 성능도 보장 될 것이다.


○ DB 구조
create table t_expn(
  expn_date date,
  dept_nm varchar(60),
  user_nm varchar(60),
  expn_amt numeric(20)
  );


○ 샘플 데이타
insert into t_expn values('2012-03-01', '기술부', '홍길동',  1000 );
insert into t_expn values('2012-03-02', '기술부', '홍길동',  2000 );
insert into t_expn values('2012-03-03', '기술부', '홍길동',  3000 );
insert into t_expn values('2012-03-04', '기술부', '홍길동',  4000 );
insert into t_expn values('2012-03-05', '기술부', '김개똥',  5000 );
insert into t_expn values('2012-03-06', '기술부', '김개똥',  6000 );
insert into t_expn values('2012-03-07', '기술부', '김개똥',  7000 );
insert into t_expn values('2012-03-08', '기술부', '엄길순',  8000 );
insert into t_expn values('2012-03-09', '기술부', '엄길순',  9000 );
insert into t_expn values('2012-03-10', '기술부', '엄길순', 10000 );
insert into t_expn values('2012-03-11', '영업부', '영업맨', 13000 );
insert into t_expn values('2012-03-12', '영업부', '영업맨', 14000 );
insert into t_expn values('2012-03-13', '영업부', '영업맨', 15000 );
insert into t_expn values('2012-03-14', '영업부', '김영업', 16000 );
insert into t_expn values('2012-03-15', '영업부', '김영업', 17000 );
insert into t_expn values('2012-03-16', '영업부', '김영업', 18000 );


 


○ 쿼리문
select case when to_char(expn_date, 'YYYY-MM-DD')  is null  and dept_nm is not null  and user_nm is not null  then  dept_nm ||'('|| user_nm || ')'||' 소계' 
                  when to_char(expn_date, 'YYYY-MM-DD')  is null and dept_nm is not null  and user_nm is null   then  dept_nm ||' 소계'
                  when to_char(expn_date, 'YYYY-MM-DD')  is null and dept_nm is null  and user_nm is null   then '전체 합계'
                  ELSE  to_char(expn_date, 'YYYY-MM-DD') END AS [지출일자], 
         case when to_char(expn_date, 'YYYY-MM-DD')  is null  then ''
                  ELSE dept_nm END AS [부서],
         case when to_char(expn_date, 'YYYY-MM-DD')  is null  then ''
                  ELSE user_nm END AS [성명],
         to_char( sum_amt, '9,999,999') AS [지출금액]
from (   
      select  expn_date, dept_nm, user_nm, sum(expn_amt) AS sum_amt
      from t_expn AS B
      group by dept_nm, user_nm, expn_date

      with rollup
     ) AS X(expn_date, dept_nm, user_nm, sum_amt);


 

○ 실행결과
================================================
 지출일자            부서    성명    지출금액
================================================
2012-03-01         기술부 홍길동     1,000
2012-03-02         기술부 홍길동     2,000
2012-03-03         기술부 홍길동     3,000
2012-03-04         기술부 홍길동     4,000
기술부(홍길동) 소계                 10,000
2012-03-05         기술부 김개똥     5,000
2012-03-06         기술부 김개똥     6,000
2012-03-07         기술부 김개똥     7,000
기술부(김개똥) 소계                 18,000
2012-03-08         기술부 엄길순     8,000
2012-03-09         기술부 엄길순     9,000
2012-03-10         기술부 엄길순    10,000
기술부(엄길순) 소계                 27,000
기술부 소계                          55,000
2012-03-11         영업부 영업맨    13,000
2012-03-12         영업부 영업맨    14,000
2012-03-13         영업부 영업맨    15,000
영업부(영업맨) 소계                 42,000
2012-03-14         영업부 김영업    16,000
2012-03-15         영업부 김영업    17,000
2012-03-16         영업부 김영업    18,000
영업부(김영업) 소계                  51,000
영업부 소계                          93,000
전체 합계                           148,000

 

 

○ 고려사항 및 참고사항

  - 데이타 건수가 많을 경우에는 별도의 통계테이블을 설계하여 with rollup 을 사용하여 성능을 향상시킬 수 있다.
  - 위의 예시에서 개인별 소개, 부서별소개, 전체합계 소개 중 필요한 것만을 쿼리할 경우에는 where 절에서 추출 할 수 있다.

 

 


  1. join update 처리방법입니다.(연관성 있는 테이블을 조인하여 처리하는 UPDATE 구문)

    Date2012.11.30 Category질의작성 By권호일 Views20391
    Read More
  2. MySQL+XE를 CUBRID+XE로 운영하기 – mysqldump파일과 CMT사용

    Date2012.11.13 Category마이그레이션 Bycubebridge Views23071
    Read More
  3. CUBRID와 CUBRID Web Manager설치, 그리고 XE의설치 및 연동까지

    Date2012.11.13 CategoryCUBRID 매니저 Bycubebridge Views18099
    Read More
  4. CUBRID-PHP-Driver 연동가이드

    Date2012.11.13 Category응용개발 Bycubebridge Views17136
    Read More
  5. MySQL에서 CUBRID로 갈아탈 때 알아야 할 것

    Date2012.11.13 Category마이그레이션 Bycubebridge Views22612
    Read More
  6. 오라클 to CUBRID로 마이그레이션 수행 시 주의사항

    Date2012.11.12 Category응용개발 Bycubebridge Views16640
    Read More
  7. 오라클의 order by 시 first와 last 대체 사용법

    Date2012.11.12 Category마이그레이션 Bycubebridge Views20575
    Read More
  8. CUBRID에서의 BLOB/CLOB 사용시 백업 및 복구에 대한 주의 점

    Date2012.09.18 Category운영관리 Bycubebridge Views33157
    Read More
  9. 전자정부 표준프레임워크 CUBRID 사용 방법 문의 참조

    Date2012.09.17 Category기타 Bycubebridge Views20600
    Read More
  10. Windows 서버에서 [장치에 쓰기 캐싱 사용] 설정/해제에 따른 성능 차이

    Date2012.06.30 Category운영관리 By이용미 Views20231
    Read More
  11. 데이터 입력 중 디스크 공간 부족 오류가 발생하였을 때, 복구 방법

    Date2012.06.30 Category운영관리 By이용미 Views14330
    Read More
  12. 게시판 응용 중 조회수로 정렬하는 경우 인덱스 생성 방법

    Date2012.06.23 Category질의작성 By손승일 Views13904
    Read More
  13. 문자(char, varchar)로 설계한 날짜데이타 검증하기

    Date2012.04.27 Category질의작성 By권호일 Views17829
    Read More
  14. CUBRIDManager의 접속 정보 이관

    Date2012.04.14 CategoryCUBRID 매니저 Bycubebridge Views12382
    Read More
  15. CUBRID Migration Tookit 8.4.1

    Date2012.04.14 Category마이그레이션 Bycubebridge Views11081
    Read More
  16. CUBRID 에서의 사용자 권한관리 방법

    Date2012.04.14 Category운영관리 Bycubebridge Views23651
    Read More
  17. 데이터베이스 마이그레이션(unloaddb & loaddb) 의 효과적인 수행방법

    Date2012.04.14 Category마이그레이션 Bycubebridge Views24547
    Read More
  18. 세부내역과 소계를 한개의 쿼리문장으로 수행하는 SQL

    Date2012.03.31 Category질의작성 By권호일 Views14092
    Read More
  19. 한건의 데이타를 여러건으로 조회하는 쿼리입니다.

    Date2012.03.30 Category질의작성 By권호일 Views9419
    Read More
  20. 여러건의 코드명을 한건으로 조회하는 쿼리입니다.

    Date2012.03.30 Category질의작성 By권호일 Views10753
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales