Поделиться через


USER (Transact-SQL)

Позволяет вставлять в таблицу предоставляемое системой имя текущего пользователя базы данных, если не указано значение по умолчанию.

Значок ссылки на разделСинтаксические обозначения в Transact-SQL

Синтаксис

USER

Типы возвращаемых данных

char

Замечания

Функция USER выполняет то же действие, что и системная функция USER_NAME.

Функцию USER можно указывать в ограничениях DEFAULT инструкций CREATE TABLE и ALTER TABLE либо использовать ее как любую другую стандартную функцию.

Функция USER всегда возвращает имя текущего контекста. При вызове после инструкции EXECUTE AS функция USER возвращает имя олицетворяемого контекста.

Если участник Windows производит доступ к базе данных посредством членства в группе, функция USER возвращает имя участника Windows, а не имя группы.

Примеры

А. Получение имени пользователя базы данных функцией USER

В следующем примере объявляется переменная типа char, ей присваивается текущее значение функции USER, а затем производится печать этой переменной вместе с текстовым описанием.

DECLARE @usr char(30)
SET @usr = user
SELECT 'The current user''s database username is: '+ @usr
GO

Ниже приводится результирующий набор.

----------------------------------------------------------------------- 
The current user's database username is: dbo                            

(1 row(s) affected)

Б. Применение функции USER в ограничении DEFAULT

В следующем примере создается таблица с использованием функции USER в ограничении DEFAULT для столбца менеджеров по продажам.

USE AdventureWorks;
GO
CREATE TABLE inventory22
(
 part_id int IDENTITY(100, 1) NOT NULL,
 description varchar(30) NOT NULL,
 entry_person varchar(30) NOT NULL DEFAULT USER 
)
GO
INSERT inventory22 (description)
VALUES ('Red pencil')
INSERT inventory22 (description)
VALUES ('Blue pencil')
INSERT inventory22 (description)
VALUES ('Green pencil')
INSERT inventory22 (description)
VALUES ('Black pencil')
INSERT inventory22 (description)
VALUES ('Yellow pencil')
GO

Ниже приведен запрос для получения всех данных из таблицы inventory22:

SELECT * FROM inventory22 ORDER BY part_id;
GO

Результирующий набор (обратите внимание на значение столбца entry-person):

part_id     description                    entry_person                   
----------- ------------------------------ -------------------------
100         Red pencil                     dbo                            
101         Blue pencil                    dbo                            
102         Green pencil                   dbo                            
103         Black pencil                   dbo                            
104         Yellow pencil                  dbo                            

(5 row(s) affected)

В. Применение функции USER в сочетании с предложением EXECUTE AS

Следующий пример иллюстрирует работу функции USER при вызове из сеанса олицетворения.

SELECT USER;
GO
EXECUTE AS USER = 'Mario';
GO
SELECT USER;
GO
REVERT;
GO
SELECT USER;
GO

Ниже приводится результирующий набор.

DBO
Mario
DBO