Partilhar via


SUSER_SNAME (Transact-SQL)

Retorna o nome de logon associado a um número de identificação de segurança (SID).

Ícone de vínculo de tópicoConvenções de sintaxe Transact-SQL

Sintaxe

SUSER_SNAME ( [ server_user_sid ] )

Argumentos

  • server_user_sid
    É o número de identificação de segurança do logon. server_user_sid, que é opcional, é varbinary(85). server_user_sid pode ser o número de identificação de segurança de qualquer logon SQL Server ou Microsoft usuário ou grupo do Windows. Se o server_user_sid não for especificado, serão retornadas informações sobre o usuário atual. Se contiver a palavra NULL, retornará NULL.

Tipos de retorno

nvarchar(128)

Comentários

SUSER_SNAME pode ser usado como uma restrição DEFAULT em ALTER TABLE ou CREATE TABLE. SUSER_SNAME pode ser usado em uma lista de seleção, em uma cláusula WHERE e em qualquer lugar em que uma expressão for permitida. SUSER_SNAME sempre deve ser seguido de parênteses, ainda que nenhum parâmetro seja especificado.

Quando chamado sem um argumento, SUSER_SNAME retorna o nome do contexto de segurança atual. Quando chamado sem um argumento em um lote que alternou o contexto usando EXECUTE AS, SUSER_SNAME retorna o nome do contexto representado. Quando chamado de um contexto representado, ORIGINAL_LOGIN retorna o nome do contexto original.

Exemplos

A. Usando SUSER_SNAME

O exemplo seguinte retorna o nome de logon do número de identificação de segurança com um valor de 0x01.

SELECT SUSER_SNAME(0x01);
GO

B. Usando SUSER_SNAME com um ID de segurança do usuário Windows

O exemplo seguinte retorna o nome de logon associado a um número de identificação de segurança do Windows.

SELECT SUSER_SNAME(0x010500000000000515000000a065cf7e784b9b5fe77c87705a2e0000);
GO

C. Usando SUSER_SNAME como uma restrição DEFAULT

O exemplo a seguir usa SUSER_SNAME como uma restrição DEFAULT em uma instrução CREATE TABLE.

USE AdventureWorks2008R2;
GO
CREATE TABLE sname_example
(
login_sname sysname DEFAULT SUSER_SNAME(),
employee_id uniqueidentifier DEFAULT NEWID(),
login_date  datetime DEFAULT GETDATE()
) 
GO
INSERT sname_example DEFAULT VALUES
GO

D. Chamando SUSER_SNAME em combinação com EXECUTE AS

O exemplo a seguir mostra o comportamento de SUSER_SNAME quando chamado em uma sessão representada.

SELECT SUSER_SNAME();

GO

EXECUTE AS LOGIN = 'WanidaBenShoof';

SELECT SUSER_SNAME();

REVERT;

GO

SELECT SUSER_SNAME();

GO

Este é o resultado.

sa

WanidaBenShoof

sa