如何快速查詢SQL Server所有表的數據量?

一、使用系統存儲過程

SQL Server提供了多個系統存儲過程,可以查詢資料庫中的各種信息。其中,sp_spaceused存儲過程可以返回指定表的空間使用情況,包括總空間、已用空間和剩餘空間。通過計算已用空間和總空間的比例,可以估算出相應表的數據量。

EXEC sp_spaceused 'tableName'

其中,tableName可以替換成需要查詢的表名。

但是,該方法僅僅是用來大致預估數據量,並且不包括索引和約束等元數據的空間佔用。

二、使用動態查詢

使用動態查詢是另一個快速查詢SQL Server所有表數據量的方法。通過查詢系統視圖sys.partitions獲取每張表的行數,並且過濾掉非用戶表。同時,系統存儲過程sp_tableofkeys可以查詢指定表名的主鍵信息,根據主鍵信息查詢每張表的記錄數。

DECLARE @tableName NVARCHAR(50)
DECLARE @sql NVARCHAR(MAX)

DECLARE table_cursor CURSOR FOR 
SELECT name 
FROM sys.tables 
WHERE type = 'U'

OPEN table_cursor 
FETCH NEXT FROM table_cursor INTO @tableName 

WHILE @@FETCH_STATUS = 0 
BEGIN 
    SET @sql = '
    SELECT ''' + @tableName + ''' AS TableName, 
    SUM(CASE WHEN index_id < 2 THEN row_count ELSE 0 END) AS Rows 
    FROM sys.partitions 
    WHERE OBJECT_NAME(object_id) = ''' + @tableName + ''''
    
    EXEC sp_executesql @sql
    
    FETCH NEXT FROM table_cursor INTO @tableName 
END 

CLOSE table_cursor 
DEALLOCATE table_cursor 

該方法可以準確計算每張表的記錄數,但是需要預先了解主鍵信息,且相對於其他方法速度可能較慢。

三、使用PowerShell腳本

PowerShell是用來管理和自動化Windows系統的強大工具。可以通過PowerShell來查詢SQL Server中所有表的數據量,並且像sys.partitions一樣查詢每張表的記錄數。

#引入SQL Server模塊
Import-Module sqlps -DisableNameChecking 

#SQL Server登錄信息
$serverName = "localhost"
$databaseName = "databaseName"
$username = "username"
$password = "password"

#建立SQL Server連接
$connectionString = "Server=$serverName; Database=$databaseName; User ID=$username; Password=$password; Trusted_Connection=False;"
$connection = New-Object System.Data.SqlClient.SqlConnection
$connection.ConnectionString = $connectionString
$connection.Open()

#查詢每張表的記錄數
$command = $connection.CreateCommand()
$command.CommandText = @"
SELECT
    t.NAME AS TableName,
    p.rows AS RowCounts
FROM
    sys.tables t
INNER JOIN sys.partitions p ON t.object_id = p.OBJECT_ID
WHERE
    t.is_ms_shipped = 0
    AND p.index_id IN (1,0);
"@

$result = $command.ExecuteReader()
$table = New-Object System.Data.DataTable
$table.Load($result)

#輸出表的數據數量
$table | Format-Table -AutoSize

#關閉SQL Server連接
$connection.Close()
$connection.Dispose()

使用PowerShell腳本可以快速地獲取所有表的數據量,並且可以靈活控制查詢SQL Server的方式。

原創文章,作者:CAZL,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/134423.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
CAZL的頭像CAZL
上一篇 2024-10-04 00:05
下一篇 2024-10-04 00:05

相關推薦

  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29
  • Ojlat:一款快速開發Web應用程序的框架

    Ojlat是一款用於快速開發Web應用程序的框架。它的主要特點是高效、易用、可擴展且功能齊全。通過Ojlat,開發人員可以輕鬆地構建出高質量的Web應用程序。本文將從多個方面對Oj…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29
  • Python多線程讀取數據

    本文將詳細介紹多線程讀取數據在Python中的實現方法以及相關知識點。 一、線程和多線程 線程是操作系統調度的最小單位。單線程程序只有一個線程,按照程序從上到下的順序逐行執行。而多…

    編程 2025-04-29
  • Python爬取公交數據

    本文將從以下幾個方面詳細闡述python爬取公交數據的方法: 一、準備工作 1、安裝相關庫 import requests from bs4 import BeautifulSou…

    編程 2025-04-29
  • Python兩張表數據匹配

    本篇文章將詳細闡述如何使用Python將兩張表格中的數據匹配。以下是具體的解決方法。 一、數據匹配的概念 在生活和工作中,我們常常需要對多組數據進行比對和匹配。在數據量較小的情況下…

    編程 2025-04-29
  • Hibernate日誌列印sql參數

    本文將從多個方面介紹如何在Hibernate中列印SQL參數。Hibernate作為一種ORM框架,可以通過列印SQL參數方便開發者調試和優化Hibernate應用。 一、通過配置…

    編程 2025-04-29
  • Python數據標準差標準化

    本文將為大家詳細講述Python中的數據標準差標準化,以及涉及到的相關知識。 一、什麼是數據標準差標準化 數據標準差標準化是數據處理中的一種方法,通過對數據進行標準差標準化可以將不…

    編程 2025-04-29
  • 如何使用Python讀取CSV數據

    在數據分析、數據挖掘和機器學習等領域,CSV文件是一種非常常見的文件格式。Python作為一種廣泛使用的編程語言,也提供了方便易用的CSV讀取庫。本文將介紹如何使用Python讀取…

    編程 2025-04-29

發表回復

登錄後才能評論