FireBird Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
파이어버드 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
IBPhoenix
FireBird Main site
볼랜드포럼 광고 모집

FireBird Q&A
[3015] 참조하세요.
Let's SQL [borsky] 1989 읽음    2009-02-19 01:21
참조하세요.

같은 일자의 데이터가 한건만 있을 때.
----------------------------------------
select d.*, c.전일계
from (
    select a.datetime, COALESCE(sum(b.qty), 0) as 전일계
    from tb1 as a left outer join tb1 as b on (a.datetime > b.datetime)
    group by a.datetime
    ) as c join tb1 as d on (c.datetime = d.datetime)
-----------------------------------------

같은 일자의 데이터가 여러건일 때.
----------------------------------------
select d.*, c.전일계
from (
    select a.datetime, COALESCE(sum(b.qty), 0) as 전일계
    from (
        select distinct datetime
        from tb1
        ) as a left outer join tb1 as b on (a.datetime > b.datetime)
    group by a.datetime
    ) as c join tb1 as d on (c.datetime = d.datetime)

-----------------------------------------
-----------------------------------------
파보 님이 쓰신 글 :
: Data :
: seq     name  datetime   qty
: 1       lee    20090101        1
: 2       park    20090102        2
: 3       kim    20090103       -1
: 4       choi    20090104        5
:
: Result :
: seq     name  datetime   qty  전일계
: 1       lee    20090101        1   0
: 2       park    20090102        2   1
: 3       kim    20090103       -1    3
: 4       choi    20090104        5   2
:
: 그러니까 <전일계>와 같이 이전 자료의 누적 수량을 구하고 싶습니다.
:
: 오라클에서는 connect by 문으로 해결했었엇는데...
:
: 부탁 드립니다.

+ -

관련 글 리스트
2989 이런 류의 SQL은 어떻게 작성하나요 ? 파보 2470 2009/01/08
3015     참조하세요. Let's SQL 1989 2009/02/19
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.