亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

SQL Server 得到SPID,唯一的sessionID

系統(tǒng) 3119 0

? ? ?像.net中的session一樣,假設(shè)能知道了數(shù)據(jù)庫中的sessionID,那全部的操作都能知道了,由于有了這個唯一的身份識別的標(biāo)識。

? ? ?能夠做的事情有非常多,如:當(dāng)前哪個用戶在做什么操作,在運行什么sql, 又如一個比較大的邏輯中要分別運行非常多存儲過程,

? ? 在運行這些存儲過程的過程其中,你想知道當(dāng)前運行的進(jìn)度,SQLServer正在運行哪個段sql語句,那么通過sessionID是非常easy

? ?就得到這些信息的。

??SQL Server 得到SPID,唯一的sessionID:

? ? SELECT @@SPID

? ? 曾經(jīng)我一直不知道,近期又裝了SQLServer2014,發(fā)現(xiàn)每開一個Query 界面就有一個ID出來。我就特別想知道怎么取sessionID.

以下的存儲過程是用來查看哪些sessionID正在運行什么操作。

create PROC [dbo].[dba_WhatSQLIsExecuting]
AS

BEGIN
-- Do not lock anything, and do not get held up by any locks.
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED


-- What SQL Statements Are Currently Running?
SELECT [Spid] = session_Id
, ecid
, [Database] = DB_NAME(sp.dbid)
, [User] = nt_username
, [Status] = er.status
, [Wait] = wait_type
, [Individual Query] = 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)
,[Parent Query] = qt.text
, Program = program_name
, Hostname
, nt_domain
, start_time
FROM sys.dm_exec_requests er
INNER JOIN sys.sysprocesses sp ON er.session_id = sp.spid
CROSS APPLY sys.dm_exec_sql_text(er.sql_handle)as qt
WHERE session_Id > 50 -- Ignore system spids.
AND session_Id NOT IN (@@SPID) -- Ignore this current statement.
--and DB_NAME(sp.dbid)='RangeCheckTool'
ORDER BY 1, 2
END

? ? 還能夠參考以下的文章:

? ?http://www.mssqltips.com/sqlservertip/1799/identify-last-statement-run-for-a-specific-sql-server-session/

? ?

Identify last statement run for a specific SQL Server session

Problem
I was reading a recent blog post from? Pinal Dave , SQL Server MVP, regarding? returning information on the latest query executed for a given session .? He offered up a couple options to return the last query statement executed, settling upon querying the sys.sysprocesses system compatibility view, but another way that this can be done is through the Dynamic Management Views and Functions.? The process for doing so is quite straight-forward and works in all versions of Microsoft SQL Server since DMOs (dynamic management objects) were integrated into SQL Server.?

Solution
Before proceeding we should take a second to explain what a session is.? In Microsoft SQL Server, a session is synonymous with a user process.? Previous to SQL 2005 sessions were referred to - and identified solely - as SPIDs (short for session id).? A SPID uniquely identifies a session and a SPID is unique across the SQL Server instance.? In an attempt to conform SQL Server object identifiers to be more user-friendly and to standardize a naming convention across all system objects, sessions are now identified across the DMO and system catalog views as session_id.? You'll see similar changes between previous versions of SQL Server and current versions where all object identifiers are concerned.

You can use the @@spid() system function to return the session_id of the current session as follows:

SELECT? @@SPID

For my test I get session_id = 52.

So, now that we've identified what session_id uniquely identifies the session I'm using during this demonstration, I'll do a simple query against the Northwind database.

SELECT? C.[CompanyName]??
FROM? [Northwind].dbo.[Customers]?C??
WHERE? C.[City]? =? 'Berlin'??
ORDER?BY? [C].[CompanyName]

At this point I'll now open up a separate query window in SQL Server Management Studio.? If I now execute?the first query above you'll see that this registers as a new session on the SQL Server instance:

SELECT? @@SPID

For my test I get session_id = 53

Now I can utilize the? sys.dm_exec_connections ?Dynamic Management View, in conjunction with the sys.dm_exec_sql_text ?Dynamic Management Function to return the last query statement executed against the SQL Server instance on a selected session.? In all truth, you can return the last query executed on all sessions, but for the sake of this discussion we're limiting the results based upon the session_id (52) we've identified above.? I'll present the query, then we can examine in detail what it provides for us.

SELECT? DEST. TEXT??
FROM?
sys.[dm_exec_connections]?SDEC?
? CROSS? APPLY?sys.[dm_exec_sql_text] ( SDEC.[most_recent_sql_handle] )? AS? DEST?
WHERE? SDEC.[most_recent_session_id]? =? 52?

The output for this query shows the statement that was run for session_id 52.

So what just happened?? Simply-put, we returned the results from the sys.dm_exec_connections DMV, limiting the results by the session_id (52) we identified above.? We, submitted the value contained in the most_recent_sql_handle column of this DMV to the sys.dm_exec_sql_text Dynamic Management Function.? That function then returned as text, the value of the sql_handle we passed to it.?

So what is a sql_handle?? Think of a sql_handle as a unique identifier for a query that is unique across the entire SQL Server instance.? Just as a session_id uniquely identifies a session, so does a sql_handle identify a query.? The actual value of the sql_handle column is very cryptic.? The value for the most_recent_sql_handle in this example is shown below:

SELECT? SDEC.[most_recent_sql_handle] ,? DEST.[text]??
FROM? sys.[dm_exec_connections]?SDEC?
? CROSS? APPLY?sys.[dm_exec_sql_text] ( SDEC.[most_recent_sql_handle] )? AS? DEST?
WHERE? SDEC.[most_recent_session_id]? =? 52?

Here we can see the value of the sql_handle and the text translation.

The handle itself does not really do much for us without the function call that rationalizes it into the original query text.? As you can see though, this very simple query does provide us with yet another option for returning information on what users are (or have been) doing on the SQL Server instances we support.

Next Steps

  • The Dynamic Management Objects have so much to offer the DBA.?? Check out other tips on DMOs ?from MSSQLTips.com.
  • Read more tips by the author? here .
  • Still interested in information on sysprocesses, whether as a system table (pre-SQL 2005) or system view?? Here are some? tips ?that meet your needs.

?

SQL Server 得到SPID,唯一的sessionID


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 美女18xxxx | 亚洲图片另类 | 伊在人亚洲香蕉精品播放 | ww亚洲ww在线观看国产 | 久久一本精品久久精品66 | 亚洲国产欧美国产第一区二区三区 | 中文字幕亚韩 | 在线观看深夜观看网站免费 | 久久77| 色综合天天综合网站中国 | 精品国产欧美一区二区最新 | 欧美综合图片 | 真人女人一级毛片免费视频观看 | 女人十八毛片免费特黄 | 欧美毛片性视频区 | 狠狠色丁香婷婷综合最新地址 | 99久久免费国产精精品 | 四虎麻豆 | 久久综合久美利坚合众国 | 亚洲综合视频一区 | 欧美日韩99| 亚洲视频在线精品 | jizz中国jizz女人 | 日韩男女视频 | 日韩欧美一区二区三区在线 | 欧美激情亚洲精品日韩1区2区 | 天天操天天射天天色 | www.天天干 | 国产精品你懂的 | 99热网站| 久久手机免费视频 | 国产高清一区二区三区四区 | 欧美xxxx成人免费视频 | 69日本人xxxx16—18 | 日日夜夜操视频 | 一级毛片视频 | 九九精品免费视频 | 天天曰天天干天天操 | 麻豆国产原创 | 国产精品亚洲第一区广西莫菁 | 蜜桃综合 |