Sdílet prostřednictvím


CURRENT_USER (Transact-SQL)

platí pro:SQL ServerAzure SQL DatabaseAzure SQL Managed InstanceAzure Synapse AnalyticsAnalytics Platform System (PDW)databáze SQL v Microsoft Fabric

Tato funkce vrací jméno aktuálního uživatele. Tato funkce je ekvivalentní USER_NAME().

Transact-SQL konvence syntaxe

Syntaxe

CURRENT_USER  

Návratové typy

sysname

Poznámky

CURRENT_USER vrací název aktuálního bezpečnostního kontextu. Pokud CURRENT_USER se spustí po volání k EXECUTE AS přepnutí kontextu, CURRENT_USER vrátí název napodobeného kontextu. Pokud principal Windows přistupoval k databázi prostřednictvím členství ve skupině, CURRENT_USER vrátí jméno principala Windows místo názvu skupiny.

Podívejte se na SUSER_NAME (Transact-SQL ) a SYSTEM_USER (Transact-SQL ), kde se dozvíte, jak vrátit přihlášení aktuálního uživatele.

Examples

A. Používám CURRENT_USER pro vrácení aktuálního uživatelského jména

Tento příklad vrací jméno aktuálního uživatele.

SELECT CURRENT_USER;  
GO  

B. Použití CURRENT_USER jako VÝCHOZÍHO omezení

Tento příklad vytváří tabulku, která používá CURRENT_USER jako DEFAULT omezení pro sloupec order_person na prodejní řádek.

USE AdventureWorks2022;  
GO  
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  

Tento příklad vkládá záznam do tabulky. Uživatel se jmenuje Wanida a vykonává tyto příkazy.

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

Tento dotaz vybírá všechny informace z tabulky orders22 .

SELECT * FROM orders22;  
GO  

Tady je soubor výsledků.

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. Používám CURRENT_USER z napodobeného kontextu

V tomto příkladu uživatel Wanida vykoná následující Transact-SQL kód, aby se vydával za uživatele 'Arnalfo'.

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

Tady je soubor výsledků.

Wanida
Arnalfo
Wanida

Viz také

USER_NAME (Transact-SQL)
SYSTEM_USER (Transact-SQL)
sys.database_principals (Transact-SQL)
ZMĚNIT TABULKU (Transact-SQL)
VYTVOŘIT TABULKU (Transact-SQL)
Systémové funkce (Transact-SQL)