CURRENT_USER (języka Transact-SQL)

Zwraca nazwę bieżącego użytkownika.Ta funkcja jest równoznaczne z USER_NAME().

Topic link iconKonwencje składni języka Transact-SQL

CURRENT_USER

Zwracane typy

sysname

Remarks

CURRENT_USER zwraca nazwę bieżącego kontekstu zabezpieczeń.Jeśli CURRENT_USER jest uruchamiane po wywołaniu jako wykonać przełącza kontekst, CURRENT_USER zwróci nazwę kontekście personifikowanego.Jeżeli główną systemu Windows można uzyskać dostępu do bazy danych z członkostwa w grupie, zamiast nazwy grupy powróci nazwy główne w systemie Windows.

Aby przywrócić identyfikator logowania bieżącego użytkownika, zobacz SUSER_NAME (języka Transact-SQL) i SYSTEM_USER (języka Transact-SQL).

Przykłady

A.Za pomocą CURRENT_USER zwraca nazwę bieżącego użytkownika

W poniższym przykładzie zwraca nazwę bieżącego użytkownika.

SELECT CURRENT_USER;
GO

B.Za pomocą CURRENT_USER jako ograniczenie domyślne

Poniższy przykład tworzy tabela, która korzysta z CURRENT_USER jako DEFAULT ograniczenie dla order_person Kolumna w wierszu sprzedaży.

USE AdventureWorks;
IF EXISTS (SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES
      WHERE TABLE_NAME = 'orders22')
   DROP TABLE orders22
GO
SET NOCOUNT ON
CREATE TABLE orders22
(
 order_id int IDENTITY(1000, 1) NOT NULL,
 cust_id  int NOT NULL,
 order_date smalldatetime NOT NULL DEFAULT GETDATE(),
 order_amt money NOT NULL,
 order_person char(30) NOT NULL DEFAULT CURRENT_USER
)
GO

W poniższym kodzie wstawia rekordu w tabela.Nosi nazwę użytkownika, który wykonuje instrukcje te Wanida.

INSERT orders22 (cust_id, order_amt)
VALUES (5105, 577.95)
GO
SET NOCOUNT OFF
GO

Następująca kwerenda wybiera wszystkie informacje z orders22 Tabela.

SELECT * FROM orders22;
GO

Here is the result set.

order_id    cust_id     order_date           order_amt    order_person
----------- ----------- -------------------- ------------ ------------
1000        5105        2005-04-03 23:34:00  577.95       Wanida
                        
(1 row(s) affected)

C.Za pomocą CURRENT_USER z kontekście personifikowanego

W poniższym przykładzie użytkownik Wanida wykonuje następujące czynności Transact-SQL Kod.

SELECT CURRENT_USER;
GO
EXECUTE AS USER = 'Arnalfo';
GO
SELECT CURRENT_USER;
GO
REVERT;
GO
SELECT CURRENT_USER;
GO

Here is the result set.

Wanida
Arnalfo
Wanida