Programming/MS SQL Server
[MS SQL SERVER] SYNONYM
hoojiv
2021. 10. 29. 09:59
728x90
Synonym은 동의어라는 의미로 Alias와 비슷한 개념이다.
다만 Alias의 경우 테이블 바로 옆에 사용하여 해당 쿼리에서만 사용하지만
Synonym는 한번 선언해 놓으면 어디서든 사용이 가능하다.
생성 및 삭제 방법은 간단하다.
아래 생성 구문을 통해 UserTbl2 테이블에 UserTbl_SYNONYM이라는 Synonym이 생성되었고,
select 구문을 통해 어디서든 조회가 가능하다.
--Synonym 생성
CREATE SYNONYM UserTbl_SYNONYM FOR UserTbl2;
--Synonym 삭제
DROP SYNONYM UserTbl_SYNONYM
--Synonym 조회
SELECT
name,
base_object_name,
type
FROM
sys.synonyms
ORDER BY
name;
--Synonym 테이블 조회
SELECT * FROM UserTbl_SYNONYM
Synonym을 사용하는 이점으로는 데이터베이스 개체의 이름이 긴 경우 이를 단순화하여 사용할 수 있다는 점이다. 특히 원격 데이터베이스에서도 개체를 참조할 경우 보통 이름이 길기 때문에 Synonym을 사용하여 간결하게 할 수 있다.
또, 테이블, 뷰, 프로시저 등 개체의 이름을 변경하고 싶을 때 참조하는 모든 곳을 수정해야 하는데 기존에 사용하던 이름을 Synonym으로 생성하고 개체의 이름을 바꾼다면 참조하는 다른 SQL이나 Web 등 응용 프로그램을 다시 컴파일하지 않아도 된다.
728x90
LIST