다음을 통해 공유


REVOKE 서버 사용 권한(Transact-SQL)

서버 수준의 GRANT 및 DENY 권한을 제거합니다.

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

구문

REVOKE [ GRANT OPTION FOR ] permission  [ ,...n ] 
    { TO | FROM } <grantee_principal> [ ,...n ]
        [ CASCADE ]
    [ AS <grantor_principal> ] 

<grantee_principal> ::= SQL_Server_login 
        | SQL_Server_login_mapped_to_Windows_login
    | SQL_Server_login_mapped_to_Windows_group
    | SQL_Server_login_mapped_to_certificate
    | SQL_Server_login_mapped_to_asymmetric_key
    | server_role 

<grantor_principal> ::= SQL_Server_login 
    | SQL_Server_login_mapped_to_Windows_login
    | SQL_Server_login_mapped_to_Windows_group
    | SQL_Server_login_mapped_to_certificate
    | SQL_Server_login_mapped_to_asymmetric_key
    | server_role

인수

  • permission
    서버에 대해 부여할 수 있는 사용 권한을 지정합니다. 사용 권한 목록은 이 항목의 뒤에 나오는 주의 섹션을 참조하십시오.

  • { TO | FROM } <grantee_principal>
    사용 권한을 취소할 보안 주체를 지정합니다.

  • AS <grantor_principal>
    이 쿼리를 실행하는 보안 주체가 사용 권한을 취소하는 권한을 부여할 수 있는 다른 보안 주체를 지정합니다.

  • GRANT OPTION FOR
    지정한 사용 권한을 다른 보안 주체에게 부여할 수 있는 권한이 취소됨을 나타냅니다. 사용 권한 자체는 취소되지 않습니다.

    중요 정보중요

    보안 주체에 GRANT 옵션 없이 지정된 사용 권한이 있는 경우 사용 권한 자체가 취소됩니다.

  • CASCADE
    사용 권한이 취소된 보안 주체에게 사용 권한을 부여 받거나 거부당한 다른 보안 주체의 사용 권한도 취소됨을 나타냅니다

    주의 사항주의

    WITH GRANT OPTION을 부여 받은 사용 권한이 연계되어 취소되면 해당 사용 권한의 GRANT 및 DENY가 모두 취소됩니다.

  • SQL_Server_login
    SQL Server 로그인을 지정합니다.

  • SQL_Server_login_mapped_to_Windows_login
    Windows 로그인으로 매핑된 SQL Server 로그인을 지정합니다.

  • SQL_Server_login_mapped_to_Windows_group
    Windows 그룹으로 매핑된 SQL Server 로그인을 지정합니다.

  • SQL_Server_login_mapped_to_certificate
    인증서로 매핑된 SQL Server 로그인을 지정합니다.

  • SQL_Server_login_mapped_to_asymmetric_key
    비대칭 키로 매핑된 SQL Server 로그인을 지정합니다.

  • server_role
    사용자 정의 서버 역할을 지정합니다.

주의

현재 데이터베이스가 master인 경우에만 서버 범위의 사용 권한을 취소할 수 있습니다.

REVOKE는 GRANT 및 DENY 권한을 모두 제거합니다.

REVOKE GRANT OPTION FOR를 사용하여 지정된 사용 권한을 다시 부여할 권한을 취소합니다. 보안 주체에 이를 부여할 권한이 포함된 사용 권한이 있으면 사용 권한을 부여할 권한이 취소되고 사용 권한 자체는 취소되지 않습니다. 보안 주체에 GRANT 옵션 없이 지정된 사용 권한이 있는 경우에는 사용 권한 자체가 취소됩니다.

서버 사용 권한에 대한 정보는 sys.server_permissions 카탈로그 뷰에 표시되고 서버 보안 주체에 대한 정보는 sys.server_principals 카탈로그 뷰에 표시됩니다. 서버 역할의 멤버 자격 정보는 sys.server_role_members 카탈로그 뷰에 표시됩니다.

서버는 사용 권한 계층에서 가장 높은 수준입니다. 다음 표에는 서버에서 취소될 수 있는 가장 제한적인 특정 사용 권한이 나열되어 있습니다.

서버 사용 권한

서버 사용 권한에 포함된 사용 권한

ADMINISTER BULK OPERATIONS

CONTROL SERVER

ALTER ANY AVAILABILITY GROUP

CONTROL SERVER

ALTER ANY CONNECTION

CONTROL SERVER

ALTER ANY CREDENTIAL

CONTROL SERVER

ALTER ANY DATABASE

CONTROL SERVER

ALTER ANY ENDPOINT

CONTROL SERVER

ALTER ANY EVENT NOTIFICATION

CONTROL SERVER

ALTER ANY EVENT SESSION

CONTROL SERVER

ALTER ANY LINKED SERVER

CONTROL SERVER

ALTER ANY LOGIN

CONTROL SERVER

ALTER ANY SERVER AUDIT

CONTROL SERVER

ALTER ANY SERVER ROLE

CONTROL SERVER

ALTER RESOURCES

CONTROL SERVER

ALTER SERVER STATE

CONTROL SERVER

ALTER SETTINGS

CONTROL SERVER

ALTER TRACE

CONTROL SERVER

AUTHENTICATE SERVER

CONTROL SERVER

CONNECT SQL

CONTROL SERVER

CONTROL SERVER

CONTROL SERVER

CREATE ANY DATABASE

ALTER ANY DATABASE

CREATE AVAILABILITY GROUP

ALTER ANY AVAILABILITY GROUP

CREATE DDL EVENT NOTIFICATION

ALTER ANY EVENT NOTIFICATION

CREATE ENDPOINT

ALTER ANY ENDPOINT

CREATE TRACE EVENT NOTIFICATION

ALTER ANY EVENT NOTIFICATION

EXTERNAL ACCESS ASSEMBLY

CONTROL SERVER

SHUTDOWN

CONTROL SERVER

UNSAFE ASSEMBLY

CONTROL SERVER

VIEW ANY DATABASE

VIEW ANY DEFINITION

VIEW ANY DEFINITION

CONTROL SERVER

VIEW SERVER STATE

ALTER SERVER STATE

사용 권한

CONTROL SERVER 권한 또는 sysadmin 고정 서버 역할의 멤버 자격이 필요합니다.

1.로그인에서 사용 권한 취소

다음 예에서는 SQL Server 로그인 WanidaBenshoof에서 VIEW SERVER STATE 권한을 취소합니다.

USE master;
REVOKE VIEW SERVER STATE FROM WanidaBenshoof;
GO

2.WITH GRANT 옵션 취소

다음 예에서는 SQL Server 로그인 JanethEsteves에서 CONNECT SQL을 부여할 수 있는 권한을 취소합니다.

USE master;
REVOKE GRANT OPTION FOR CONNECT SQL FROM JanethEsteves;
GO

로그인에는 CONNECT SQL 권한이 계속 있지만 이 권한을 더 이상 다른 보안 주체에 부여할 수 없습니다.

참고 항목

참조

GRANT(Transact-SQL)

DENY(Transact-SQL)

DENY 서버 사용 권한(Transact-SQL)

REVOKE 서버 사용 권한(Transact-SQL)

sys.fn_builtin_permissions(Transact-SQL)

sys.fn_my_permissions(Transact-SQL)

HAS_PERMS_BY_NAME(Transact-SQL)

개념

사용 권한 계층(데이터베이스 엔진)