SQL Server DMV ve DMF Kavramları ve Kullanımları -5
Merhaba Arkadaşlar,
Bu yazımda SQL Server da yine DMV ve DMF konusuna devam edeceğim. Bu yazımda ise sistemde çalışan anlık sorguları,processleri ve bu processlerin çalıştırdıkları sorguların neler olduğunu göstereceğim.

SQL Server da internal toollar içerisinden SQL Server Activity monitor ve SQL Profiller toollarıda aşağıdaki scriptlerin görevlerini yapabilmektedir. Ancak bu scriptleri kullanarak Management Datawarehouse gibi bir repository kurabilir böylece geçmişe dönük bu verileri saklayabilir ve sistemin durumunu analiz edebilirsiniz.
Sistemde çalışan anlık processler ve bunların durumunu aşağıdaki scriptle sorgulayabilirsiniz. Bu script Adam Machanic in yazmış olduğu ve çokça kullanılan sp_whoisactive stored procedure ü benzeri bir görev görür.
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
SELECT
SPID = er.session_id
,BlkBy = er.blocking_session_id
,ElapsedMS = er.total_elapsed_time
,CPU = er.cpu_time
,IOReads = er.logical_reads + er.reads
,IOWrites = er.writes
,Executions = ec.execution_count
,CommandType = er.command
,ObjectName = OBJECT_SCHEMA_NAME(qt.objectid,dbid) + '.' + OBJECT_NAME(qt.objectid, qt.dbid)
,SQLStatement =
SUBSTRING
(
qt.text,
er.statement_start_offset/2,
(CASE WHEN er.statement_end_offset = -1
THEN LEN(CONVERT(nvarchar(MAX), qt.text)) * 2
ELSE er.statement_end_offset
END - er.statement_start_offset)/2
)
,Status = ses.status
,[Login] = ses.login_name
,Host = ses.host_name
,DBName = DB_Name(er.database_id)
,LastWaitType = er.last_wait_type
,StartTime = er.start_time
,Protocol = con.net_transport
,transaction_isolation =
CASE ses.transaction_isolation_level
WHEN 0 THEN 'Unspecified'
WHEN 1 THEN 'Read Uncommitted'
WHEN 2 THEN 'Read Committed'
WHEN 3 THEN 'Repeatable'
WHEN 4 THEN 'Serializable'
WHEN 5 THEN 'Snapshot'
END
,ConnectionWrites = con.num_writes
,ConnectionReads = con.num_reads
,ClientAddress = con.client_net_address
,Authentication = con.auth_scheme
FROM sys.dm_exec_requests er
LEFT JOIN sys.dm_exec_sessions ses ON ses.session_id = er.session_id
LEFT JOIN sys.dm_exec_connections con ON con.session_id = ses.session_id
CROSS APPLY sys.dm_exec_sql_text(er.sql_handle) as qt
OUTER APPLY
(
SELECT execution_count = MAX(cp.usecounts)
FROM sys.dm_exec_cached_plans cp
WHERE cp.plan_handle = er.plan_handle
) ec
ORDER BY
er.blocking_session_id DESC,
er.logical_reads + er.reads DESC,
Executions;
Scriptin çıktısı aşağıdaki gibidir.

SQL Server veritabanımız üzerinde CPU da aktif bir şekilde çalışan sorguları ise aşağıdaki scriptle görebilirsiniz. Bu script sayesinde bitmeyen sorguları görebilir ve neden bitmediğini araştırabilirsiniz. Bu script bir nevi SQL Monitoring görevi görür.
select text,
SUBSTRING(st.text, (qs.statement_start_offset/2)+1,
((CASE qs.statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset
END - qs.statement_start_offset)/2) + 1) AS statement_text,
* from sys.dm_exec_requests qs
cross apply sys.dm_exec_sql_text(sql_handle) st
cross apply sys.dm_exec_query_plan(plan_handle);
Scriptin çıktısı aşağıdaki gibidir.

Böylece bir yazımın daha sonuna gelmiş bulunmaktayım bir sonraki yazıda görüşmek dileğiyle esen kalın..