SUSER_SNAME (Transact-SQL)
Retorna o nome de logon associado a um número de identificação de segurança (SID).
Aplica-se a: SQL Server (SQL Server 2008 até a versão atual), Banco de dados SQL do Windows Azure (versão inicial até a versão atual). |
Convenções da sintaxe Transact-SQL
Sintaxe
SUSER_SNAME ( [ server_user_sid ] )
Argumentos
server_user_sid
Aplica-se a: SQL Server 2008 a SQL Server 2014.
É o número opcional de identificação de segurança do logon. server_user_sid é varbinary(85). server_user_sid pode ser o número de identificação de segurança de qualquer logon do SQL Server, ou usuário ou grupo do Microsoft Windows. Se o server_user_sid não for especificado, serão retornadas informações sobre o usuário atual. Se o parâmetro 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.
Banco de dados SQL do Windows Azure Comentários
SUSER_NAME sempre retorna o nome de logon para o contexto de segurança atual.
A instrução SUSER_SNAME não oferece suporte à execução usando um contexto de segurança representado por meio de EXECUTE AS.
Exemplos
A.Usando SUSER_SNAME
O exemplo a seguir retorna o nome de logon para o contexto de segurança atual.
SELECT SUSER_SNAME();
GO
B.Usando SUSER_SNAME com um identificador de segurança de usuário do Windows
O exemplo seguinte retorna o nome de logon associado a um número de identificação de segurança do Windows.
Aplica-se a: SQL Server 2008 a SQL Server 2014. |
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 AdventureWorks2012;
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
Este exemplo mostra o comportamento de SUSER_SNAME quando chamado de um contexto representado.
Aplica-se a: SQL Server 2008 a SQL Server 2014. |
SELECT SUSER_SNAME();
GO
EXECUTE AS LOGIN = 'WanidaBenShoof';
SELECT SUSER_SNAME();
REVERT;
GO
SELECT SUSER_SNAME();
GO
Este é o resultado.
sa
WanidaBenShoof
sa
Consulte também
Referência
sys.server_principals (Transact-SQL)