Заметка
Доступ к этой странице требует авторизации. Вы можете попробовать войти в систему или изменить каталог.
Доступ к этой странице требует авторизации. Вы можете попробовать сменить директорию.
Применимо к:SQL Server
База данных Azure SQL
Управляемый экземпляр Azure SQL
Azure Synapse Analytics
Система платформы аналитики (PDW)
Конечная точка SQL аналитики в Microsoft Fabric
Хранилище в Microsoft Fabric
База данных SQL в Microsoft Fabric
Возвращает одну строку на сеанс с проверкой подлинности в SQL Server.
sys.dm_exec_sessions — это представление области сервера, отображающее сведения обо всех активных подключениях пользователей и внутренних задачах. Эти сведения включают в себя данные о версии клиента, имени клиентской программы, времени входа, имени входа пользователя, текущих настройках сеанса и т.д. Используется sys.dm_exec_sessions для первого просмотра текущей загрузки системы и определения интересующего сеанса, а затем получения дополнительных сведений об этом сеансе с помощью других динамических административных представлений или динамических функций управления.
sys.dm_exec_connections
sys.dm_exec_sessions Представление sys.dm_exec_requestsсовместимости системы sys.sysprocesses и динамические административные представления сопоставляются с устаревшим представлением совместимости системы.
Примечание.
Чтобы назвать этот вид из Azure Synapse Analytics (только выделенный SQL-пул) или Analytics Platform System (PDW), см. sys.dm_pdw_nodes_exec_sessions. Используйте sys.dm_exec_sessions Azure Synapse Analytics (только серверный SQL-пул) или Microsoft Fabric.
| Имя столбца | Тип данных | Нуллибельный | Description |
|---|---|---|---|
session_id |
smallint | нет | Идентификатор сеанса, связанный со всеми активными первичными соединениями. |
login_time |
datetime | нет | Время подключения сеанса. Сеансы, которые не полностью вошли в систему во время запроса динамического административного представления, отображаются с временем 1900-01-01входа. |
host_name |
nvarchar(128) | Да | Название клиентской рабочей станции, специфичное для сессии. Значение — NULL для внутренних сеансов.Примечание по безопасности. Клиентское приложение предоставляет имя рабочей станции и может предоставлять неточные данные. Не полагаться на HOST_NAME функцию безопасности. |
program_name |
nvarchar(128) | Да | Имя клиентской программы, которая инициировала сеанс. Значение — NULL для внутренних сеансов. |
host_process_id |
int | Да | Идентификатор процесса клиентской программы, которая инициировала сеанс. Значение — NULL для внутренних сеансов. |
client_version |
int | Да | TDS-версия интерфейса, используемого клиентом для подключения к серверу. Значение — NULL для внутренних сеансов. |
client_interface_name |
nvarchar(32) | Да | Имя библиотеки или драйвера, используемого клиентом для взаимодействия с сервером. Значение — NULL для внутренних сеансов. |
security_id |
varbinary(85) | нет | Идентификатор безопасности Windows, связанный с именем входа. |
login_name |
nvarchar(128) | нет | Имя входа SQL Server, под которым выполняется текущий сеанс. Исходный имя входа, создавший сеанс, см. в разделе original_login_name. Может быть именем пользователя домена, прошедшим проверку подлинности SQL Server, или именем пользователя домена, прошедшим проверку подлинности Windows. |
nt_domain |
nvarchar(128) | Да | Домен Windows для клиента, если во время сеанса применяется проверка подлинности Windows или доверительное соединение. Это значение предназначено для внутренних сеансов и пользователей, не относящихся NULL к домену. |
nt_user_name |
nvarchar(128) | Да | Имя пользователя Windows для клиента, если во время сеанса используется проверка подлинности Windows или доверительное соединение. Это значение предназначено для внутренних сеансов и пользователей, не относящихся NULL к домену. |
status |
nvarchar(30) | нет | Состояние сеанса. Возможные значения:Running — В настоящее время выполняется один или несколько запросовSleeping - В настоящее время выполнение запросов не выполняетсяDormant — Сеанс был сброшен из-за пула подключений и теперь находится в состоянии предварительной записи.Preconnect — Сеанс находится в классификаторе регулятора ресурсов. |
context_info |
varbinary(128) | Да |
CONTEXT_INFO значение сеанса. Сведения о контексте задаются пользователем с помощью инструкции SET CONTEXT_INFO . |
cpu_time |
int | нет | Время ЦП в миллисекундах, используемое этим сеансом. |
memory_usage |
int | нет | Количество 8-килобайтовых страниц памяти, используемых данным сеансом. |
total_scheduled_time |
int | нет | Общее время, назначенное данному сеансу (включая его вложенные запросы) для исполнения, в миллисекундах. |
total_elapsed_time |
int | нет | Время, прошедшее с момента установки сеанса в миллисекундах. |
endpoint_id |
int | нет | Идентификатор конечной точки, связанной с сеансом. |
last_request_start_time |
datetime | нет | Время, когда начался последний запрос данного сеанса. На этот раз включает текущий исполняемый запрос. |
last_request_end_time |
datetime | Да | Время завершения последнего запроса в рамках данного сеанса. |
reads |
bigint | нет | Количество физических чтений, выполненных по запросам в этой сессии, за эту сессию. |
writes
1 |
bigint | нет | Количество физических записей, выполненных по запросам в этой сессии, в течение этой сессии. |
logical_reads |
bigint | нет | Количество логических операций чтения, выполняемых запросами в этом сеансе, во время этого сеанса. |
is_user_process |
bit | нет |
0 Значение , если сеанс является системным сеансом. В противном случае возвращается 1. |
text_size |
int | нет |
TEXTSIZE параметр сеанса. |
language |
nvarchar(128) | Да |
LANGUAGE параметр сеанса. |
date_format |
nvarchar(3) | Да |
DATEFORMAT параметр сеанса. |
date_first |
smallint | нет |
DATEFIRST параметр сеанса. |
quoted_identifier |
bit | нет |
QUOTED_IDENTIFIER параметр сеанса. |
arithabort |
bit | нет |
ARITHABORT параметр сеанса. |
ansi_null_dflt_on |
bit | нет |
ANSI_NULL_DFLT_ON параметр сеанса. |
ansi_defaults |
bit | нет |
ANSI_DEFAULTS параметр сеанса. |
ansi_warnings |
bit | нет |
ANSI_WARNINGS параметр сеанса. |
ansi_padding |
bit | нет |
ANSI_PADDING параметр сеанса. |
ansi_nulls |
bit | нет |
ANSI_NULLS параметр сеанса. |
concat_null_yields_null |
bit | нет |
CONCAT_NULL_YIELDS_NULL параметр сеанса. |
transaction_isolation_level |
smallint | нет | Уровень изоляции транзакции данного сеанса:0 = Unspecified1 = ReadUncommitted2 = ReadCommitted3 = RepeatableRead4 = Serializable5 = Snapshot |
lock_timeout |
int | нет |
LOCK_TIMEOUT параметр сеанса. Значение указывается в миллисекундах. |
deadlock_priority |
int | нет |
DEADLOCK_PRIORITY параметр сеанса. |
row_count |
bigint | нет | Количество строк, возвращенных сеансом на текущий момент времени. |
prev_error |
int | нет | Идентификатор последней ошибки, возвращенной в данном сеансе. |
original_security_id |
varbinary(85) | нет | Идентификатор безопасности Windows, связанный original_login_nameс . |
original_login_name |
nvarchar(128) | нет | Имя входа SQL Server, используемое клиентом для создания этого сеанса. Может быть именем входа, прошедшим проверку подлинности SQL Server, именем пользователя домена, прошедшим проверку подлинности Windows, или пользователем автономной базы данных. Сессия могла проходить через множество неявных или явных переключений контекста после начального соединения, например, если используется EXECUTE AS . |
last_successful_logon |
datetime | Да | Время последнего успешного входа в original_login_name систему до начала текущего сеанса. |
last_unsuccessful_logon |
datetime | Да | Время последней неудачной попытки входа в original_login_name систему до начала текущего сеанса. |
unsuccessful_logons |
bigint | Да | Число неудачных попыток входа между original_login_namelast_successful_logon и login_time. |
group_id |
int | нет | Идентификатор группы рабочей нагрузки, которой принадлежит этот сеанс. |
database_id |
smallint | нет | Идентификатор текущей базы данных для каждого сеанса. В База данных SQL Azure значения уникальны в одной базе данных или эластичном пуле, но не в логическом сервере. Применимо: SQL Server 2012 (11.x) и более поздних версий. |
authenticating_database_id |
int | Да | Идентификатор базы данных, выполняющей проверку подлинности участника. Для имен входа используется 0значение . Для пользователей автономной базы данных значением является идентификатор базы данных автономной базы данных.Применимо: SQL Server 2012 (11.x) и более поздних версий. |
open_transaction_count |
int | нет | Количество открытых транзакций на сеанс. Применимо: SQL Server 2012 (11.x) и более поздних версий. |
pdw_node_id |
int | нет | Идентификатор узла, на который находится данное распределение. Область применения: Azure Synapse Analytics и система платформы аналитики (PDW). |
page_server_reads |
bigint | нет | Количество операций чтения сервера страниц, выполняемых запросами в этом сеансе, во время этого сеанса. Применимо к: База данных SQL Azure гипермасштабирование. |
contained_availability_group_id |
uniqueidentifier | Да | ID содержащейся группы доступности. Относится к: SQL Server 2025 (17.x) и более поздним версиям. |
1 Указывает, когда страница отмечена как «грязная» в буферном пуле. Это значение напрямую не соответствует реальным записям, потому что одна и та же страница может быть отмечена более одного раза. Эти счетчики агрегируются в конце партии.
Разрешения
Каждый может просматривать свои собственные сведения о сеансе.
В SQL Server 2019 (15.x) и более ранних версиях требуется VIEW SERVER STATE просмотреть все сеансы на сервере. В SQL Server 2022 (16.x) и более поздних версиях требуется VIEW SERVER PERFORMANCE STATE разрешение на сервере.
В База данных SQL требуется VIEW DATABASE STATE просмотреть все подключения к текущей базе данных.
VIEW DATABASE STATE невозможно предоставить в master базе данных.
Замечания
common criteria compliance enabled Если включен параметр конфигурации сервера, статистика входа отображается в следующих столбцах.
last_successful_logonlast_unsuccessful_logonunsuccessful_logons
Если этот параметр не включен, эти столбцы возвращают значения NULL. Для получения дополнительной информации о том, как настроить эту опцию конфигурации сервера, см. раздел «Включить конфигурацию соответствия общим критериям».
Подключения администратора на База данных SQL Azure отображают одну строку для каждого сеанса проверки подлинности. Сеансы sa , отображаемые в наборе результатов, не влияют на квоту пользователя для сеансов. Подключения, не относящиеся к администратору, видят только сведения, связанные с сеансами пользователей базы данных.
Из-за различий в том, как они записываются, open_transaction_count может не соответствовать sys.dm_tran_session_transactions.open_transaction_count.
Кратности связей
| С дт. | По | Подключить/Применить | Отношение |
|---|---|---|---|
sys.dm_exec_sessions |
sys.dm_exec_requests | session_id |
Один к нулю или один ко многим. |
sys.dm_exec_sessions |
sys.dm_exec_connections | session_id |
Один к нулю или один ко многим. |
sys.dm_exec_sessions |
sys.dm_tran_session_transactions | session_id |
Один к нулю или один ко многим. |
sys.dm_exec_sessions |
sys.dm_exec_cursors (session_id | 0) |
session_id CROSS APPLYOUTER APPLY |
Один к нулю или один ко многим. |
sys.dm_exec_sessions |
sys.dm_db_session_space_usage | session_id |
Взаимно-однозначный |
Примеры
А. Поиск пользователей, подключенных к серверу
В следующем примере производится поиск пользователей, подключенных к серверу, и возвращаются сведения о числе сеансов для каждого пользователя.
SELECT login_name,
COUNT(session_id) AS session_count
FROM sys.dm_exec_sessions
GROUP BY login_name;
B. Поиск длительных курсоров
В следующем примере находятся курсоры, открытые более определенного периода времени, которые создали курсоры и на каком сеансе находятся курсоры.
USE master;
GO
SELECT creation_time,
cursor_id,
name,
c.session_id,
login_name
FROM sys.dm_exec_cursors(0) AS c
INNER JOIN sys.dm_exec_sessions AS s
ON c.session_id = s.session_id
WHERE DATEDIFF(mi, c.creation_time, GETDATE()) > 5;
В. Поиск бездействующих сеансов с открытыми транзакциями
В следующем производится поиск сеансов, имеющих открытые транзакции, но при этом бездействующих. Бездействующим сеансом считается сеанс, который в настоящий момент не выполняет запросов.
SELECT s.*
FROM sys.dm_exec_sessions AS s
WHERE EXISTS (SELECT *
FROM sys.dm_tran_session_transactions AS t
WHERE t.session_id = s.session_id)
AND NOT EXISTS (SELECT *
FROM sys.dm_exec_requests AS r
WHERE r.session_id = s.session_id);
D. Поиск сведений о собственном подключении запроса
В следующем примере собираются сведения о собственном подключении запроса:
SELECT c.session_id,
c.net_transport,
c.encrypt_option,
c.auth_scheme,
s.host_name,
s.program_name,
s.client_interface_name,
s.login_name,
s.nt_domain,
s.nt_user_name,
s.original_login_name,
c.connect_time,
s.login_time
FROM sys.dm_exec_connections AS c
INNER JOIN sys.dm_exec_sessions AS s
ON c.session_id = s.session_id
WHERE c.session_id = @@SPID;