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

使用一個T-SQL語句批量查詢數據表占用空間及其

系統 2108 0
原文: 使用一個T-SQL語句批量查詢數據表占用空間及其行數

?

要找到數據庫中數據表占用的空間和存在的行數。可以使用sp_spaceused搭配數據表的名稱。就可以產生該表耗用的空間和現有行數。

如:

USE ADVENTUREWORKS

GO

EXEC sp_spaceused [Sales.SalesOrderHeader]

GO

?

?

但如果數據庫中包含數千的數據表,如何能利用一句SQL語句來實現?

?

解決方法:

一、動態SQL:

先用T-SQL動態產生表達式,然后放到一個查詢中執行。如:

USE ADVENTUREWORKS

GO

SET NOCOUNT ON

SELECT 'EXEC SP_SPACEUSED [' + S . name + '.' + T . name + '];'

FROM sys . tables T INNER JOIN sys . schemas S

ON T . SCHEMA_ID = S . SCHEMA_ID

WHERE S . NAME = 'HumanResources'

SET NOCOUNT OFF

結果如下:

使用一個T-SQL語句批量查詢數據表占用空間及其行數

把結果復制到新的窗口執行即可得到結果。

但這種方法需要人手操作不適合自動化、定時化操作。

二、使用累加字符串的方式動態生成:

因為要自動化,所以會利用數據表的INSERT觸發器,執行動態表達式。并且自動將輸入的數據表,計算結果:

-- 建立表,執行 insert 觸發器

USE AdventureWorks

GO

CREATE TABLE myTab

(

??? TableName VARCHAR ( 255 )

)

GO

?

?

-- 建立觸發器:

CREATE TRIGGER tr2 ON myTab

AFTER INSERT

AS

??? DECLARE @sql VARCHAR ( max )

??? SET @sql = ''

??????? -- 使用累加字符串,產生語句

??? SELECT @sql = @sql +

??????????? ??????????? 'EXEC sp_spaceused [' + TableName + ']; '

??????????? FROM inserted

??????????? -- 利用 EXECUTE 執行動態語句

??? EXEC ( @sql )

?

-- 新增指定的數據表名稱,會自動顯示數據表的使用空間:

INSERT myTab

SELECT S . name + '.' + T . name

FROM sys . tables T INNER JOIN sys . schemas S

ON T . schema_id = S . schema_id

WHERE S . name = 'HumanResources'

?

? 使用一個T-SQL語句批量查詢數據表占用空間及其行數

使用一個T-SQL語句批量查詢數據表占用空間及其行數


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日日夜夜噜噜 | 中文字幕在线免费播放 | 99热久久这里只有精品2010 | 国产欧美精品一区二区三区–老狼 | 久久久国产精品免费看 | 欧美精品综合一区二区三区 | 香蕉视频黄网站 | 99九九国产精品免费视频 | 黄色片网站在线观看 | 狠狠干中文字幕 | 日本人一级大毛片 | 黄页网址在线免费观看 | 国产伦精品一区二区三区视频小说 | 久久久久免费精品视频 | 99精品高清视频一区二区 | 国内精品久久久久久影院8f | 国内精品久久久久激情影院 | 国产精品爱久久久久久久9999 | 色老板女色狠xx网 | 日韩精品一区二三区中文 | 欧美日韩亚洲精品一区二区 | 日b黄色 | 亚洲精品一区二区三区香蕉在线看 | 日日射天天射 | 色综合天天综久久久噜噜噜久久〔 | 日本精品一二三区 | 伊人久久大香线焦综合四虎 | x8x8国产日韩欧美 | 久久免费国产 | 香蕉免费一级视频在线观看 | 国产在线观看美女福利精 | 欧美日本另类xxx乱大交 | 色哥网站| 999精品国产 | 久久狠狠 | 亚洲福利一区福利三区 | 欧美日韩视频在线 | 黄色网址视频在线播放 | 亚洲欧美综合一区二区三区四区 | xxxxx日本59| 久久精品国产免费中文 |