sys.database_principals(Transact-SQL)

데이터베이스의 각 주체에 대해 행을 반환합니다.

열 이름

데이터 형식

설명

name

sysname

데이터베이스 내에서 고유한 보안 주체의 이름입니다.

principal_id

int

데이터베이스 내에서 고유한 보안 주체의 ID입니다.

유형

char(1)

보안 주체 유형입니다.

S = SQL 사용자

U = Windows 사용자

G = Windows 그룹

A = 응용 프로그램 역할

R = 데이터베이스 역할

C = 인증서로 매핑된 사용자

K = 비대칭 키로 매핑된 사용자

type_desc

nvarchar(60)

보안 주체 유형에 대한 설명입니다.

SQL_USER

WINDOWS_USER

WINDOWS_GROUP

APPLICATION_ROLE

DATABASE_ROLE

CERTIFICATE_MAPPED_USER

ASYMMETRIC_KEY_MAPPED_USER

default_schema_name

sysname

SQL 이름이 스키마를 지정하지 않을 때 사용되는 이름입니다. S, U 또는 A 유형의 보안 주체의 경우 Null입니다.

create_date

datetime

보안 주체가 생성된 시간입니다.

modify_date

datetime

보안 주체가 마지막으로 수정된 시간입니다.

owning_principal_id

int

이 보안 주체를 소유하는 보안 주체의 ID입니다. 데이터베이스 역할을 제외한 모든 보안 주체는 dbo가 소유해야 합니다.

sid

varbinary(85)

보안 주체의 SID(보안 식별자)입니다. SYS 및 INFORMATION SCHEMAS의 경우 NULL입니다.

is_fixed_role

bit

1이면 이 행은 고정 데이터베이스 역할 db_owner, db_accessadmin, db_datareader, db_datawriter, db_ddladmin, db_securityadmin, db_backupoperator, db_denydatareader, db_denydatawriter 중 하나의 항목을 나타냅니다.

authentication_type

int

인증 유형을 나타냅니다.

설명

0

인증 없음

1

인스턴스 인증

2

데이터베이스 인증

3

Windows 인증

SQL Azure에 적용되지 않습니다.

authentication_type_desc

nvarchar(60)

인증 유형에 대한 설명입니다.

설명

NONE

인증 없음

INSTANCE

인스턴스 인증

DATABASE

데이터베이스 인증

WINDOWS

Windows 인증

SQL Azure에 적용되지 않습니다.

default_language_name

sysname

이 보안 주체의 기본 언어를 나타냅니다.

SQL Azure에 적용되지 않습니다.

default_language_lcid

int

이 보안 주체의 기본 LCID를 나타냅니다.

SQL Azure에 적용되지 않습니다.

주의

PasswordLastSetTime 속성은 SQL Server에서 지원하는 모든 구성에서 사용할 수 있지만 다른 속성은 SQL Server가 Windows Server 2003에서 실행 중이고 CHECK_POLICY 및 CHECK_EXPIRATION이 모두 설정된 경우에만 사용할 수 있습니다. 자세한 내용은 암호 정책을 참조하십시오.

사용 권한

모든 사용자는 자신의 사용자 이름, 시스템 사용자 및 고정 데이터베이스 역할을 볼 수 있습니다. 다른 사용자를 보려면 사용자에 대한 ALTER ANY USER 또는 사용 권한이 필요합니다. 사용자 정의 역할을 보려면 ALTER ANY ROLE 또는 역할의 멤버 자격이 필요합니다.

A: 데이터베이스 보안 주체의 모든 사용 권한 나열

다음 쿼리는 데이터베이스 보안 주체에 대해 명시적으로 부여되거나 거부된 사용 권한을 나열합니다.

중요 정보중요

고정 데이터베이스 역할의 사용 권한은 sys.database_permissions에 나타나지 않습니다. 따라서 데이터베이스 보안 주체가 여기에 나열되지 않은 추가 사용 권한을 가질 수 있습니다.

SELECT pr.principal_id, pr.name, pr.type_desc, 
    pr.authentication_type_desc, pe.state_desc, pe.permission_name
FROM sys.database_principals AS pr
JOIN sys.database_permissions AS pe
    ON pe.grantee_principal_id = pr.principal_id;

B: 데이터베이스 내의 스키마 개체에 대한 사용 권한 나열

다음 쿼리는 sys.database_principals 및 sys.database_permissions를 sys.objects 및 sys.schemas에 조인하여 특정 스키마 개체에 부여되거나 거부된 사용 권한을 나열합니다.

SELECT pr.principal_id, pr.name, pr.type_desc, 
    pr.authentication_type_desc, pe.state_desc, 
    pe.permission_name, s.name + '.' + o.name AS ObjectName
FROM sys.database_principals AS pr
JOIN sys.database_permissions AS pe
    ON pe.grantee_principal_id = pr.principal_id
JOIN sys.objects AS o
    ON pe.major_id = o.object_id
JOIN sys.schemas AS s
    ON o.schema_id = s.schema_id;

참고 항목

참조

카탈로그 뷰(Transact-SQL)

보안 카탈로그 뷰(Transact-SQL)

개념

보안 주체(데이터베이스 엔진)