* Procedure 의 결과 내용을 select 하고 싶을 땐 openqurey 를 이용해서 select 할수 있다
  - 리턴되는 형식이 일정하지 않아도 됨
----------------------------------------------------------------------------------------------
OPENQUERY(링크드서버명,'exec 프로시저명') : 반드시 링크드서버로 구성이 되어야 한다.
SELECT  *
INTO    #tmpTable
FROM   
----------------------------------------------------------------------------------------------
 
 * 이게 귀찮다면 temp table 을 선언하여 insert 후 select 하는 방법도 있다.
   -단, 리턴되는 형식이 일정해야함
----------------------------------------------------------------------------------------------
​INSERT 템프테이블 EXEC 프로시저
CREATE TABLE #TEMPTABLE
(
 id varchar(max),
 name varchar(max),
 [group] varchar(max)
)
INSERT #TEMPTABLE EXEC test_procedure
SELECT * FROM #TEMPTABLE
----------------------------------------------------------------------------------------------

 

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

+ Recent posts

티스토리 툴바