join 대상 테이블의 값중에

특정 컬럼이 값이 max인 데이터만을 가지고

join 하고 싶을 때 아래와 같이 사용합니다.

 

SQL Server 2005 이상에서는 아래와 같이

-----------------------------------------

SELECT  *
FROM    JOB A
          OUTER APPLY
           
(
           
SELECT  TOP 1 *
           
FROM    JOBSTATUS B
           
WHERE   B.JOBID = A.JOBID
           
ORDER BY B.seq DESC
           
) B

-----------------------------------------

 

그 전 버전에서는

-----------------------------------------

SELECT  *
FROM    JOB A
            LEFT JOIN
            JOBSTATUS B
            ON   B.ID =
                                 (
                                 SELECT  TOP 1 ID
                                 FROM    JOBSTATUS C
                                 WHERE   C.JOBID = A.JOBID
                                 ORDER BY C.SEQ DESC
                                 )

-----------------------------------------

 

참고

http://stackoverflow.com/questions/4851949/joining-to-max-date-record-in-group

'DB' 카테고리의 다른 글

(MSSQL) 프로시저에서 " 허용 (더블커테이션)  (0) 2017.04.13
(MSSQL) select procedure (OPENQUERY)  (0) 2017.04.13
(MSSQL) MAX 값과 join 하기  (0) 2017.04.13
(MSSQL) Sequence  (0) 2017.04.13
(MSSQL) 트리거 (Trigger)  (0) 2017.04.13
(MSSQL) TOP(N) 데이터 몇건만 가져오기  (0) 2017.04.13

프로젝트를 진행하다보니

프로시저 내에서 씨리얼하게 값을 증가시켜 데이터를 저장해야 하는일이 생겼다

프로시저내에서 전역변수를 선언할수는 없고

테이블을 하나 만들어서 컬럼을 identity 열로 지정하여 가져올까도 했지만 Transaction 이 발생되서 ... GG

코딩상으로는 전역변수 int 하나 만들어놓고 ++ 시키면 되는데

SQL 은 그런 기능이 없나 하다가 찾게된 기능

코딩상에서 전역변수를 사용하는것과 비슷하다.

 

시퀀스 하나 만들고 (SQL 2012 에서만 지원된다.)

-----------------------------------------

CREATE SEQUENCE TESTIDX AS INT
START WITH 1 -- 시작수
INCREMENT BY 1 -- 증가수

-----------------------------------------

 

프로시저내에서 아래와 같이 활용하면 된다.

-----------------------------------------

NEXT VALUE FOR TESTIDX

-----------------------------------------

 

SEQUENCE 는 지정숫자부터 증가하게하거나 초기화 및 띄어넘기가 가능하다

'DB' 카테고리의 다른 글

(MSSQL) select procedure (OPENQUERY)  (0) 2017.04.13
(MSSQL) MAX 값과 join 하기  (0) 2017.04.13
(MSSQL) Sequence  (0) 2017.04.13
(MSSQL) 트리거 (Trigger)  (0) 2017.04.13
(MSSQL) TOP(N) 데이터 몇건만 가져오기  (0) 2017.04.13
(MSSQL) 오류상태 파악 함수  (0) 2017.04.13

CREATE TRIGGER trg_testDelete -- 트리거 이름

ON TEST -- 테이블 이름

AFTER UPDATE,DELETE -- update 후에 작동하게 지정 (DELETE, INSERT)

AS

INSERT INTO TEST2

SELECT * FROM updated -- (deleted, inserted)

 

INSERT INTO TEST2

SELECT * FROM deleted

 

TEST 테이블이 없데이트 될때 TEST2 테이블에 데이터가 insert 되도록 동작

 

----------------------------------------------------------------------------------------------

 

CREATE TRIGGER trg_testDelete -- 트리거 이름

ON TEST -- 테이블 이름

INSTEAD OF INSERT -- Insert 이전에 작동하게 지정 (DELETE, INSERT)

AS

INSERT INTO TEST2

SELECT * FROM inserted

 

----------------------------------------------------------------------------------------------

테이블에 연관된 trigger 확인 프로시저.

exec sp_helptrigger 테이블명

예) exec sp_helptrigger TEST_JUN

'DB' 카테고리의 다른 글

(MSSQL) MAX 값과 join 하기  (0) 2017.04.13
(MSSQL) Sequence  (0) 2017.04.13
(MSSQL) 트리거 (Trigger)  (0) 2017.04.13
(MSSQL) TOP(N) 데이터 몇건만 가져오기  (0) 2017.04.13
(MSSQL) 오류상태 파악 함수  (0) 2017.04.13
(MSSQL) identity 컬럼 조작하기 (CHECKIDENT)  (0) 2017.04.13

+ Recent posts