久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

獲取SQL Server的當前連接數

瀏覽:6日期:2023-10-30 15:53:37

首先聲明:這個問題我沒有解決

當網友問到我這個問題時,我也還以為很簡單,以為SQL Server應該提供了對應的系統變量什么的.但是到目前為止,我還沒有得到一個比較好的解決方案.可能很簡單,,只不過我不知道罷了.希望如此..

下面我說說相關的知識吧.希望大家可以給出一個比較好的方法.

這里有幾個與之相關的概念.

SQL Server提供了一些函數返回連接值(這里可不是當前連接數喲!),個人覺得,很容易產生誤解.

系統變量

@@CONNECTIONS 返回自上次啟動 Microsoft® SQL Server™ 以來連接或試圖連接的次數。

@@MAX_CONNECTIONS 返回 Microsoft® SQL Server™ 上允許的同時用戶連接的最大數。返回的數不必為當前配置的數值。

系統存儲過程

SP_WHO

提供關于當前 Microsoft® SQL Server™ 用戶和進程的信息。可以篩選返回的信息,以便只返回那些不是空閑的進程。

列出所有活動的用戶:SP_WHO ‘active’

列出某個特定用戶的信息:SP_WHO ‘sa’

系統表

Sysprocesses

sysprocesses 表中保存關于運行在 Microsoft® SQL Server™ 上的進程的信息。這些進程可以是客戶端進程或系統進程。sysprocesses 只存儲在 master 數據庫中。

Sysperfinfo

包括一個 Microsoft® SQL Server™ 表示法的內部性能計數器,可通過 Windows NT 性能監視器顯示.

有人提議說為了獲取SQL Server的當前連接數:使用如下SQL:

SELECT COUNT(*) AS CONNECTIONS FROM master..sysprocesses

個人認為不對,看看.sysprocesses的login_time列就可看出.

另外一個方面是進程不能和連接相提并論,他們是一對一的關系嗎,也就是說一個進程就是一個連接?一個連接應該有多個進程的,所以連接和進程之間的關系應該是1:n的.

因為sysprocesses列出的進程包含了系統進程和用戶進程,為了得到用戶連接,可以使用如下SQL:

SELECT cntr_value AS User_Connections FROM master..sysperfinfo as pWHERE p.object_name = 'SQLServer:General Statistics' And p.counter_name = 'User Connections'

個人還是認為不對,因為它是一個計數器,可能會累加的.

還有一種方案是利用如下SQL:

select connectnum=count(distinct net_address)-1 from master..sysprocesses

理由是net_address是訪問者機器的網卡值,這個總該是唯一的吧.但是看起來得到的是所有時間內的連接數.

希望大家可以給出自己的解決方案.這個問題解決了,相信會有很大的用途.

http://confach.cnblogs.com/archive/2006/05/31/414156.html

標簽: Sql Server 數據庫
主站蜘蛛池模板: 成人福利影院 | 国产欧美久久久久久 | 亚洲婷婷综合网 | 亚洲91精品 | 欧美激情高清 | 国产一区二区三区免费观看 | 精品伦理一区二区三区 | 成人国产一区二区 | 在线观看中文视频 | 一区二区三区视频在线观看 | 亚洲精品一二三区 | 亚洲国产成人精品女人 | 国产精品不卡 | 蜜桃av在线播放 | 日韩一级片 | 日韩高清中文字幕 | 日韩在线观看中文字幕 | 国产淫片在线观看 | 久久久精品一区二区 | 精品一二区 | 日韩国产欧美视频 | 成人h视频在线观看 | 久久精品久久久久电影 | 奇米二区| 日本一区二区中文字幕 | 国产精品视频一二三 | 日本欧美久久久久免费播放网 | av中文字幕在线播放 | 中文字幕久久久 | 日韩精品一区二区三区老鸭窝 | 99热婷婷| 久久精品性视频 | 97视频观看| 在线欧美日韩 | 国产亚洲一区二区三区 | 中文字幕在线免费视频 | 偷拍自拍第一页 | 免费一区 | 在线国产区 | 欧美午夜精品一区二区三区电影 | 久草中文在线 |