다음을 통해 공유


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

적용 대상: SQL Server Azure SQL Managed Instance

서버 수준의 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

적용 대상: SQL Server (SQL Server 2012(11.x) ~ 현재 버전).
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

적용 대상: SQL Server (SQL Server 2012(11.x) ~ 현재 버전).
CONTROL SERVER
ALTER RESOURCES CONTROL SERVER
ALTER SERVER STATE CONTROL SERVER
ALTER SETTINGS CONTROL SERVER
ALTER TRACE CONTROL SERVER
AUTHENTICATE SERVER CONTROL SERVER
CONNECT ANY DATABASE

적용 대상: SQL Server (SQL Server 2014(12.x) ~ 현재 버전).
CONTROL SERVER
CONNECT SQL CONTROL SERVER
CONTROL SERVER CONTROL SERVER
CREATE ANY DATABASE ALTER ANY DATABASE
CREATE AVAILABILITY GROUP

적용 대상: SQL Server (SQL Server 2012(11.x) ~ 현재 버전).
ALTER ANY AVAILABILITY GROUP
CREATE DDL EVENT NOTIFICATION ALTER ANY EVENT NOTIFICATION
CREATE ENDPOINT ALTER ANY ENDPOINT
CREATE SERVER ROLE

적용 대상: SQL Server (SQL Server 2012(11.x) ~ 현재 버전).
ALTER ANY SERVER ROLE
CREATE TRACE EVENT NOTIFICATION ALTER ANY EVENT NOTIFICATION
EXTERNAL ACCESS ASSEMBLY CONTROL SERVER
IMPERSONATE ANY LOGIN

적용 대상: SQL Server (SQL Server 2014(12.x) ~ 현재 버전).
CONTROL SERVER
SELECT ALL USER SECURABLES

적용 대상: SQL Server (SQL Server 2014(12.x) ~ 현재 버전).
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 고정 서버 역할의 멤버 자격이 필요합니다.

예제

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

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

USE master;  
REVOKE VIEW SERVER STATE FROM WanidaBenshoof;  
GO  

B. 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)