-- 설명이 있는 테이블 리스트
SELECT objtype, objname, name, value FROM::fn_listextendedproperty (NULL, 'schema', 'dbo', 'table', default, default,default)
-- 설명이 있는 Temp 테이블의 필드 리스트
SELECT objtype, objname, name, value FROM::fn_listextendedproperty (NULL, 'schema', 'dbo', 'table', 'Temp','column', default)
-- Temp테이블의 설명을 추가하기
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'설명테스트 테이블', @level0type=N'SCHEMA',@level0name=N'dbo',@level1type=N'TABLE',@level1name=N'Temp'
-- Temp테이블의 설명을 수정하기
EXEC sys.sp_updateextendedproperty @name=N'MS_Description', @value=N'설명테스트 테이블', @level0type=N'SCHEMA',@level0name=N'dbo',@level1type=N'TABLE',@level1name=N'Temp'
-- Temp테이블의 field1필드에 설명을 추가하기
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'설명테스트' ,@level0type=N'SCHEMA',@level0name=N'dbo',@level1type=N'TABLE',
@level1name=N'Temp', @level2type=N'COLUMN',@level2name=N'field1'
-- Temp테이블의 field1필드에 설명을 수정하기
EXEC sys.sp_updateextendedproperty @name=N'MS_Description', @value=N'설명테스트', @level0type=N'SCHEMA',@level0name=N'dbo',@level1type=N'TABLE',@level1name=N'Temp',
@level2type=N'COLUMN',@level2name=N'field1'
위와 같이 작업하면 동적으로 테이블이나 컬럼에 설명을 추가할 수 있고
Class를 Generated 할 때 사용할 수 있다.
ErWin에서 디자인시 논리적 뷰를 설명으로 대체해서 입력하고
Create 구문을 자동 생성할 때 위 구문을 추구하는 pre set을 만들어서 동기화를 하고
Class를 Generated할 때 위 정보를 활용하여 intellisense를 나타내도록 구현 한다면
ERWin –> MSSQL Schema –> Generated Class Structure로 일관성 있게 유지될 수 있을 것이다.
다만 역 방향으로의 reverse enginnering 되지 않는다는 단점이 있다.
다음 시간에는 ERWin에서 위 구문을 이용해서 Create에 추가할 수 있는 방법을 알아 보겠다.