다음을 통해 공유


sp_column_privileges(Transact-SQL)

현재 환경 내의 단일 테이블에 대한 열 권한 정보를 반환합니다.

항목 링크 아이콘Transact-SQL 구문 표기 규칙

구문

sp_column_privileges [ @table_name = ] 'table_name' 
     [ , [ @table_owner = ] 'table_owner' ] 
     [ , [ @table_qualifier = ] 'table_qualifier' ] 
     [ , [ @column_name = ] 'column' ]

인수

[ @table_name = ] 'table_name'

카탈로그 정보를 반환하는데 사용되는 테이블입니다. table_namesysname이며 기본값은 없습니다. 와일드카드 패턴 일치는 지원되지 않습니다.

[ @table_owner = ] 'table_owner'

카탈로그 정보를 반환하는 데 사용되는 테이블의 소유자입니다. table_ownersysname이며 기본값은 NULL입니다. 와일드카드 패턴 일치는 지원되지 않습니다. table_owner를 지정하지 않은 경우에는 기본 DBMS(데이터베이스 관리 시스템)의 기본 테이블 표시 규칙이 적용됩니다.

SQL Server 2005 에서는 현재 사용자가 지정한 이름의 테이블을 소유하고 있는 경우 해당 테이블의 열이 반환됩니다. table_owner가 지정되지 않고 현재 사용자가 table_name이 지정된 테이블을 소유하지 않은 경우에는 sp_column privileges에서 데이터베이스 소유자가 소유한 table_name이 지정된 테이블을 찾습니다. 테이블이 있으면 테이블의 열이 반환됩니다.

[ @table_qualifier = ] 'table_qualifier'

테이블 한정자의 이름입니다. table_qualifiersysname이며 기본값은 NULL입니다. 다양한 DBMS 제품에서 테이블에 세 부분으로 이루어진 이름(qualifier**.owner.**name)을 지원합니다. SQL Server 에서 이 열은 데이터베이스 이름을 나타냅니다. 일부 제품에서는 테이블 데이터베이스 환경의 서버 이름을 나타냅니다.

[ @column_name = ] 'column'

카탈로그 정보 중 한 열만 확보될 때 사용되는 단일 열입니다. column은 **nvarchar(384)**이며 기본값은 NULL입니다. column을 지정하지 않으면 모든 열이 반환됩니다. SQL Server 에서 columnsys.columns 테이블에 나열된 열 이름을 의미합니다. column은 기본 DBMS의 와일드카드 일치 패턴을 사용하는 와일드카드 문자를 포함할 수 있습니다. 상호 운용성을 극대화하려면 게이트웨이 클라이언트에서 SQL-92 표준 패턴 일치(% 및 _ 와일드카드 문자)만 사용해야 합니다.

결과 집합

sp_column_privileges는 ODBC의 SQLColumnPrivileges와 같습니다. 반환된 결과는 TABLE_QUALIFIER, TABLE_OWNER, TABLE_NAME, COLUMN_NAMEPRIVILEGE 순으로 정렬됩니다.

열 이름 데이터 형식 설명

TABLE_QUALIFIER

sysname

테이블 한정자의 이름입니다. 이 필드는 NULL이 될 수 있습니다.

TABLE_OWNER

sysname

테이블 소유자의 이름입니다. 이 필드는 항상 값을 반환합니다.

TABLE_NAME

sysname

테이블의 이름입니다. 이 필드는 항상 값을 반환합니다.

COLUMN_NAME

sysname

반환된 TABLE_NAME의 각 열 이름입니다. 이 필드는 항상 값을 반환합니다.

GRANTOR

sysname

나열된 GRANTEE에게 해당 COLUMN_NAME에 대한 권한을 부여한 데이터베이스 사용자 이름입니다. SQL Server 에서 이 열은 항상 TABLE_OWNER와 같습니다. 이 필드는 항상 값을 반환합니다.

GRANTOR 열은 데이터베이스 소유자(TABLE_OWNER)이거나 또는 데이터베이스 소유자가 GRANT 문에 WITH GRANT OPTION 절을 사용하여 권한을 부여한 사용자가 될 수 있습니다.

GRANTEE

sysname

나열된 GRANTOR에 의해 해당 COLUMN_NAME에 대한 권한을 부여받은 데이터베이스 사용자 이름입니다. SQL Server 에서 이 열은 항상 sysusers 테이블의 한 명의 데이터베이스 사용자를 포함합니다. 이 필드는 항상 값을 반환합니다.

PRIVILEGE

varchar(32)

사용할 수 있는 열 사용 권한 중의 하나입니다. 열 사용 권한은 다음 값(또는 구현이 정의될 때 데이터 원본이 지원하는 다른 값) 중 하나일 수 있습니다.

SELECT = GRANTEE는 열에 대한 데이터를 검색할 수 있습니다

INSERT = GRANTEEGRANTEE에 의해 새 행이 테이블에 삽입될 때 이 열에 대한 데이터를 제공할 수 있습니다.

UPDATE = GRANTEE는 열의 기존 데이터를 수정할 수 있습니다.

REFERENCES = GRANTEE는 기본 키/외래 키 관계에 있는 외래 테이블의 열을 참조할 수 있습니다. 기본 키/외래 키 관계는 테이블 제약 조건을 사용하여 정의됩니다.

IS_GRANTABLE

varchar(3)

GRANTEE가 다른 사용자에게 권한을 부여할 수 있도록 허용할지 여부를 나타냅니다. 이것을 "권한 부여 권한"이라고도 합니다. YES, NO 또는 NULL이 될 수 있습니다. 알 수 없는 값(또는 NULL)은 "권한 부여 권한"을 적용할 수 없는 데이터 원본을 의미합니다.

주의

SQL Server 의 경우 GRANT 문으로 사용 권한을 부여하고 REVOKE 문으로 사용 권한을 제거합니다.

사용 권한

스키마에 대한 SELECT 권한이 필요합니다.

다음 예에서는 특정 열에 대한 열 권한 정보를 반환하는 방법을 보여 줍니다.

USE AdventureWorks;
GO
EXEC sp_column_privileges @table_name = 'Employee', 
   @table_owner = 'HumanResources', 
   @table_qualifier = 'AdventureWorks',
   @column_name = 'SalariedFlag'

참고 항목

참조

GRANT(Transact-SQL)
REVOKE(Transact-SQL)
시스템 저장 프로시저(Transact-SQL)

관련 자료

분산 쿼리

도움말 및 정보

SQL Server 2005 지원 받기