查詢某資料庫中的所有資料表
SELECT name as table_name
FROM sysobjects
WHERE xtype='u'
ORDER BY name
查詢某資料庫中的所有資料表及其資料總條數
SELECT a.name 資料表,
b.rows 資料總條數,
RTRIM(8 * b.dpages) + ' KB' 占用空間大小
FROM sysobjects AS a
INNER JOIN sysindexes AS b ON a.id = b.id
WHERE ( a.type = 'u' ) AND ( b.indid IN ( 0, 1 ) )
ORDER BY b.dpages DESC,b.rows DESC;
查詢資料庫檔案路徑資訊
select * from sys.database_files
查詢資料庫檔案大小
--當前資料庫服務器所有資料庫檔案大小
SELECT DB_NAME(database_id) AS DatabaseName,
Name AS Logical_Name,
Physical_Name, (size*8.0)/1024 SizeMB
FROM sys.master_files
GO
--查看某一個資料庫的檔案大小
SELECT DB_NAME(database_id) AS DatabaseName,
Name AS Logical_Name,
Physical_Name, (size*8.0)/1024 SizeMB
FROM sys.master_files
WHERE DB_NAME(database_id) = 'database資料庫名'
GO
SQL SERVER 統計每張表的大小
建存盤程序
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- 說明:更新查詢資料庫中各表的大小,結果存盤到資料表中
-- =============================================
CREATE PROCEDURE [dbo].[P_GetTableSpaceInfo]
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 P_GetTableSpaceInfo
SELECT * FROM temp_tableSpaceInfo;
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/522984.html
標籤:SQL Server
上一篇:說說 Redis 事務
下一篇:教你處理數倉慢SQL常見定位問題
