SQL SERVER 2012查詢資料庫和所有表的大小方法彙總

chenfeng發表於2021-03-26

檢視某個庫和某張表的大小:

# sqlcmd -S 192.168.0.1 -U SA -P 'XXXXXXX'

1> use test

2> go

已將資料庫上下文更改為 'test'。

1> EXEC sp_spaceused

2> go

database_name                                                                                                                    database_size      unallocated space

-------------------------------------------------------------------------------------------------------------------------------- ------------------ ------------------

test                                                                                                                               358392.19 MB       61140.89 MB      

reserved           data               index_size         unused           

------------------ ------------------ ------------------ ------------------

303655216 KB       151521704 KB       150348640 KB       1784872 KB       

1>

2>

3>

4>

5> EXEC sp_spaceused 'owe_test';

6> go

name                                                                                                                             rows                 reserved           data               index_size         unused           

-------------------------------------------------------------------------------------------------------------------------------- -------------------- ------------------ ------------------ ------------------ ------------------

owe_test                                                                                                                        23044925             90553168 KB        28877832 KB        61365144 KB        310192 KB        

1> 


查詢test資料庫中的所有表的大小

方法1:

use test

將資料庫上下文更改為 'test'。

CREATE PROCEDURE [dbo].[sp_UpdateTableSpaceInfo]

AS

BEGIN

    --查詢是否存在結果儲存表

    IF NOT EXISTS (SELECT * FROM sysobjects where id = OBJECT_ID(N'temp_tableSpaceInfo') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)

    BEGIN

        --不存在則建立

        CREATE TABLE temp_tableSpaceInfo

        (name NVARCHAR(128),

        rows char(11),

        reserved VARCHAR(18),

        data VARCHAR(18),

        index_size VARCHAR(18),

        unused VARCHAR(18))

    END

    --清空資料表

    DELETE FROM temp_tableSpaceInfo


    --定義臨時變數在遍歷時儲存表名稱

    DECLARE @tablename VARCHAR(255)


    --使用遊標讀取資料庫內所有表表名

    DECLARE table_list_cursor CURSOR FOR

    SELECT name FROM sysobjects

    WHERE OBJECTPROPERTY(id, N'IsTable') = 1 AND name NOT LIKE N'#%%' ORDER BY name

--開啟遊標

    OPEN table_list_cursor

    --讀取第一條資料

    FETCH NEXT FROM table_list_cursor INTO @tablename


    --遍歷查詢到的表名

    WHILE @@FETCH_STATUS = 0

    BEGIN

        --檢查當前表是否為使用者表

        IF EXISTS (SELECT * FROM sysobjects WHERE id = OBJECT_ID(@tablename) AND OBJECTPROPERTY(id, N'IsUserTable') = 1)

        BEGIN

            --當前表則讀取其資訊插入到表格中

            EXECUTE sp_executesql N'INSERT INTO temp_tableSpaceInfo EXEC sp_spaceused @tbname', N'@tbname varchar(255)', @tbname = @tablename

        END

        --讀取下一條資料

        FETCH NEXT FROM table_list_cursor INTO @tablename

    END


    --釋放遊標

    CLOSE table_list_cursor

    DEALLOCATE table_list_cursor

END


GO


使用的時候,執行下面的語句:


EXEC sp_UpdateTableSpaceInfo;

go

SELECT * FROM temp_tableSpaceInfo;

go



方法2:

use test

將資料庫上下文更改為 'test'。

declare  @table_spaceused table

(name  nvarchar(100)

,rows  int

,reserved  nvarchar(100)

,data  nvarchar(100)

,index_size nvarchar(100)

,unused nvarchar(100)

)


insert into @table_spaceused

(name,rows,reserved,data,index_size,unused )

exec sp_MSforeachtable

@command1='exec sp_spaceused ''?'''


select * from @table_spaceused;

go


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-2765155/,如需轉載,請註明出處,否則將追究法律責任。

相關文章