강의 컨설팅 트레이닝 무료진단 무료책자 마케팅편지 마케팅정보공유 다이어리 서비스제휴 고객센터

SQL Server에서 글로벌 변수 구현하기
작성자 : 99 단국강토
등록날짜 : 2008.12.30 16:58
1,970

SQL Server에서 글로벌 변수(Global Variable) 구현하기

<?XML:NAMESPACE PREFIX = O />

 

 

한대성

MS SQL Server MVP

에이디컨설팅 책임 컨설턴트 | SQLLeader.com 운영자

블로그에 재미있는 주제와 관련된 글이 올라와서 이를 활용해서 소개해 드립니다.

#TempTable 과 같이 테이블 명 앞에 #을 붙이게 되면 이 테이블의 정보는 현재 세션에서 계속 사용할 수 있습니다.

이와 비슷한 방식으로 저장 프로시저 또는 쿼리를 작성하다 보면 값이 저장된 변수를 재정의하지 않고 지속적으로 사용해야 할 경우가 종종 있습니다. 하지만, SQL에서 변수는 하나의 일괄 처리 내에서만 사용 가능합니다. 동일한 세션에서 정의되고 값이 지정되더라도 “GO”로 일괄 처리가 끝나게 되면 다시 변수를 정의해야 하며, 이미 지정한 값은 사라지게 됩니다.

DECLARE @GlobalVar int

SET @GlobalVar = 10

 

SELECT @GlobalVar

GO

 

SELECT @GlobalVar+1

GO

 

/*

-----------

10

(1 적용됨)

 

메시지 137, 수준15, 상태 2, 2

스칼라 변수"@GlobalVar"() 선언해야 합니다.

*/

두 번째 SELECT 문에서 @GlobalVar 변수를 사용하려고 하지만, 이미 변수가 정의된 후, GO로 일괄처리가 끝났기 때문에 더 이상 @GlobalVar 변수는 존재하지 않으며 위와 같이 에러가 발생합니다.

 

현재의 세션에서 값을 유지하기 위한 방법으로 CONTEXT_INFO라는 기능을 이용할 수 있습니다. CONTEXT_INFO는 세션 별로 varbinary(128)의 값을 저장할 수 있는 기능이며, 세션 당 한 개가 존재합니다. SQL 2005에서는 sys.dm_exec_sessions, SQL 2000에서는 master.dbo.sysprocesses 테이블에서 CONTEXT_INFO 값을 확인할 수 있으며, 쿼리에서는 CONTEXT_INFO()로 값을 읽어올 수 있습니다.

 

) CONTEXT_INFO를 사용하여 값 저장하기 구현

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

-- 1) <?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" /><?XML:NAMESPACE PREFIX = ST1 /><?xml:namespace prefix = st2 ns = "urn:schemas:contacts" /><?XML:NAMESPACE PREFIX = ST2 />자형 값을 저장

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

DECLARE @BinVar as varbinary(128)

SET @BinVar = CAST('ABCDEFG' AS VARBINARY(128))

SET CONTEXT_INFO @BinVar

GO

 

SELECT session_id, context_info FROM sys.dm_exec_sessions

WHERE session_id = @@spid

GO

/*

session_id context_info

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

51           0x41424344454647

*/

 

 

SELECT CAST(CONTEXT_INFO() AS CHAR)

GO

SELECT CAST(CONTEXT_INFO() AS CHAR)

GO

/*

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

ABCDEFG                      

 

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

ABCDEFG                       

*/

 

 

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

-- 2) 숫자형 값을 저장 (숫자를 문자형으로 변환한 , 저장)

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

DECLARE @BinVar as varbinary(128)

SET @BinVar = CAST(CAST(123456 AS CHAR) AS VARBINARY(128))

SET CONTEXT_INFO @BinVar

GO

 

SELECT CAST(CAST(CONTEXT_INFO() AS CHAR) AS INT)

GO

SELECT CAST(CAST(CONTEXT_INFO() AS CHAR) AS INT) + 100000

GO

 

/*

123456

 

223456

*/

 

CONTEXT_INFO를 이용하는 방식이 간단하기는 하지만, 다음과 같은 한계가 있습니다.

A.      세션당 한 개만 사용할 수 있음

B.      VARBINARY(128) 데이터만 저장 가능. 다른 유형의 데이터는 변형해야 함

 

 

다음에 소개되는 스크립트는 이러한 점을 해결할 수 있는 방식입니다. 테이블과 이 테이블에 데이터를 입력하고 출력하는 저장 프로시저를 이용하는 방식입니다.

USE master

GO

 

IF OBJECT_ID('dbo.sp_GlobalVariables') IS NOT NULL

    DROP TABLE dbo.sp_GlobalVariables

GO

CREATE TABLE dbo.sp_GlobalVariables

(

    varName VARCHAR(100),

    varValue SQL_VARIANT

)

GO

 

IF OBJECT_ID('dbo.sp_GetGlobalVariableValue') IS NOT NULL

    DROP PROC dbo.sp_GetGlobalVariableValue

GO

CREATE PROC dbo.sp_GetGlobalVariableValue

(

    @varName VARCHAR(100),

    @varValue SQL_VARIANT = NULL OUTPUT

)

AS

    SET NOCOUNT ON   

    -- 출력 변수 설정

    SELECT    @varValue = varValue

    FROM    sp_globalVariables

    WHERE    varName = @varName

"쇼핑몰·홈페이지·오픈마켓
블로그·페이스북·이메일 등의 각종 마케팅 글쓰기,
각종 광고, 영업, 판매, 제안서, 전단지
반응율 3배×10배 이상 높이는 마법의 8단계 공식"
자세히보기

Comments

번호 제목 글쓴이 날짜 조회
2415 [MSSQL] OPENROWSET 13 김영철 01.23 2959
2414 OpenRowSet 이용하여 엑셀파일 DB로 저장하기 13 김영철 01.23 3492
2413 MSSQL DBA GUIDE - 테이블 관리 13 김영철 01.23 2879
2412 우편번호 검색 DB 13 김영철 01.23 2282
2411 [MSSQL] DB 생성 및 용량수정 13 김영철 01.23 3455
2410 웹프로그래밍 언어별 데이터베이스연결 (ASP편) 13 김영철 01.23 2930
2409 [SQL] 페이징 처리 13 김영철 01.23 2898
2408 [MSSQL] 그룹별 상위 n명 가져오기 예제 13 김영철 01.23 2711
2407 [MS SQL] 랜덤 추출 13 김영철 01.23 2592
2406 MS-SQL SERVER 2000 개론 [강력추천] 13 김영철 01.23 1984
2405 [SQL 2005 업그레이드 가이드] SQL Server 2005 설치 13 김영철 01.23 2625
2404 MSSQL 2005 Q&A 13 김영철 01.23 2860
2403 DBA라면 이 정도는 알고 있어야 하지 않을까요 !!! 13 김영철 01.23 1575
2402 검색 in 부분에대한 프로시져 처리법 13 김영철 01.23 2142
2401 [MSSQL]데이터베이스 옵션 설정 99 단국강토 01.12 3053
2400 set xact_abort on 사용시 주의점.(2) 99 단국강토 01.12 2898
2399 MSSQL 프로시져 만들기 99 단국강토 01.08 2093
2398 [MS-SQL]동적SQL을 만들때 유의사항-2 99 단국강토 01.08 1861
2397 [MS-SQL]동적SQL을 만들때 유의사항-1 99 단국강토 01.08 3682
2396 DBMS에 따른 날짜포맷 변환 99 단국강토 01.07 2307
2395 MSSQL 기본 접속 포트 1433 변경 및 서버 alias 사용 99 단국강토 01.07 3940
2394 MSSQL SERVER에서 접속 port 변경하기 99 단국강토 01.06 2887
2393 검색어 로그 리스트 뽑는 퀄리... 99 단국강토 01.06 1645
2392 T-SQL: Parameter Sniffing 쿼리 튜닝 99 단국강토 01.05 2180
2391 mssql 2005 [퀄리분석기 단축키설정] -SSMS 99 단국강토 01.05 2650
2390 퀄럼이름 쉽게 가져오기 99 단국강토 01.03 2989
2389 MSSQL 내장 함수 목록 99 단국강토 01.03 2150
2388 동적 쿼리의 해결사 sp_executesql vs. exec 99 단국강토 01.02 2950
2387 MsSql 날짜 함수 99 단국강토 01.02 2044
열람중 SQL Server에서 글로벌 변수 구현하기 99 단국강토 12.30 1971
마케팅
특별 마케팅자료
다운로드 마케팅자료
창업,경영
기획,카피,상품전략
동기부여,성취