मूल: मेरे MS SQL सर्वर DB की डिस्क पर आकार क्या है?
अधिक: क्या मैं जल्दी से देख सकता हूं कि डेटा कहां है? यानी टेबल, लॉग, आदि
मूल: मेरे MS SQL सर्वर DB की डिस्क पर आकार क्या है?
अधिक: क्या मैं जल्दी से देख सकता हूं कि डेटा कहां है? यानी टेबल, लॉग, आदि
जवाबों:
आप शायद sp_spaceused कमांड से शुरू करना चाहते हैं।
उदाहरण के लिए:
डेटाबेस के कुल आकार के बारे में sp_spaceused रिटर्न की जानकारी
sp_spaceused 'MyTable' MyTable के आकार के बारे में जानकारी लौटाता है
उन सभी चीजों के लिए डॉक्स पढ़ें जिनके बारे में आप जानकारी प्राप्त कर सकते हैं। आप एक ही बार में सभी तालिकाओं के खिलाफ sp_spaceused को चलाने के लिए sp_msforeachtable कमांड का उपयोग कर सकते हैं।
संपादित करें: अवगत रहें कि कमांड कभी-कभी कई डेटासेट लौटाता है, प्रत्येक सेट में आँकड़ों का एक अलग हिस्सा होता है।
यह स्क्रिप्ट वर्तमान डेटाबेस में सभी तालिकाओं के माध्यम से लूप करती है और दिखाती है कि डेटा, इंडेक्स और अप्रयुक्त के लिए प्रत्येक व्यक्ति कितना स्थान लेता है:
http://sqlserverpedia.com/wiki/Calculate_Current_Table_Sizes
आप भौतिक फ़ाइलों को देख सकते हैं sys.database_files
। यह फ़ाइल और आकार (ब्लॉक IIRC में) का पथ है।
sp_spaceused
आपको दिखाएगा कि कोई व्यक्ति कितनी जगह लेता है।
प्रति तालिका आकार प्राप्त करने के लिए इसे चलाएं:
/******************************************************************************
** File: “GetTableSpaceUsage.sql”
** Name: Get Table Space Useage for a specific schema
** Auth: Robert C. Cain
** Date: 01/27/2008
**
** Desc: Calls the sp_spaceused proc for each table in a schema and returns
** the Table Name, Number of Rows, and space used for each table.
**
** Called by:
** n/a – As needed
**
** Input Parameters:
** In the code check the value of @schemaname, if you need it for a
** schema other than dbo be sure to change it.
**
** Output Parameters:
** NA
*******************************************************************************/
/*—————————————————————————*/
/* Drop the temp table if it's there from a previous run */
/*—————————————————————————*/
if object_id(N'tempdb..[#TableSizes]') is not null
drop table #TableSizes ;
go
/*—————————————————————————*/
/* Create the temp table */
/*—————————————————————————*/
create table #TableSizes
(
[Table Name] nvarchar(128) /* Name of the table */
, [Number of Rows] char(11) /* Number of rows existing in the table. */
, [Reserved Space] varchar(18) /* Reserved space for table. */
, [Data Space] varchar(18) /* Amount of space used by data in table. */
, [Index Size] varchar(18) /* Amount of space used by indexes in table. */
, [Unused Space] varchar(18) /* Amount of space reserved but not used. */
) ;
go
/*—————————————————————————*/
/* Load the temp table */
/*—————————————————————————*/
declare @schemaname varchar(256) ;
-- Make sure to set next line to the Schema name you want!
set @schemaname = 'dbo' ;
-- Create a cursor to cycle through the names of each table in the schema
declare curSchemaTable cursor
for select sys.schemas.name + '.' + sys.objects.name
from sys.objects
, sys.schemas
where object_id > 100
and sys.schemas.name = @schemaname
/* For a specific table uncomment next line and supply name */
--and sys.objects.name = 'specific-table-name-here'
and type_desc = 'USER_TABLE'
and sys.objects.schema_id = sys.schemas.schema_id ;
open curSchemaTable ;
declare @name varchar(256) ; /* This holds the name of the current table*/
-- Now loop thru the cursor, calling the sp_spaceused for each table
fetch curSchemaTable into @name ;
while ( @@FETCH_STATUS = 0 )
begin
insert into #TableSizes
exec sp_spaceused @objname = @name ;
fetch curSchemaTable into @name ;
end
/* Important to both close and deallocate! */
close curSchemaTable ;
deallocate curSchemaTable ;
/*—————————————————————————*/
/* Feed the results back */
/*—————————————————————————*/
select [Table Name]
, [Number of Rows]
, [Reserved Space]
, [Data Space]
, [Index Size]
, [Unused Space]
from [#TableSizes]
order by [Table Name] ;
/*—————————————————————————*/
/* Remove the temp table */
/*—————————————————————————*/
drop table #TableSizes ;
रॉबर्ट सिने ब्लॉग से लिया गया
यह कोड Microsoft SQL 2005+ के लिए है
Start \ Programs \ Microsoft SQL Server \ Enterprise प्रबंधक चलाएँ। डेटाबेस शीट खोलें, संपत्ति% databasename% में आप स्थान डेटा फ़ाइल और लेन-देन फ़ाइलें देख सकते हैं।
यह एक क्वेरी / दृश्य है जो इस जानकारी के सभी को प्राप्त करता है, और अधिक, बिना किसी "दुष्ट" कर्सर या लूप के। ;-)
/*
vwTableInfo - Table Information View
This view display space and storage information for every table in a
SQL Server 2005 database.
Columns are:
Schema
Name
Owner may be different from Schema)
Columns count of the max number of columns ever used)
HasClusIdx 1 if table has a clustered index, 0 otherwise
RowCount
IndexKB space used by the table's indexes
DataKB space used by the table's data
16-March-2008, RBarryYoung@gmail.com
31-January-2009, Edited for better formatting
*/
--CREATE VIEW vwTableInfo
-- AS
SELECT SCHEMA_NAME(tbl.schema_id) as [Schema]
, tbl.Name
, Coalesce((Select pr.name
From sys.database_principals pr
Where pr.principal_id = tbl.principal_id)
, SCHEMA_NAME(tbl.schema_id)) as [Owner]
, tbl.max_column_id_used as [Columns]
, CAST(CASE idx.index_id WHEN 1 THEN 1 ELSE 0 END AS bit) AS [HasClusIdx]
, Coalesce( (Select sum (spart.rows) from sys.partitions spart
Where spart.object_id = tbl.object_id and spart.index_id < 2), 0) AS [RowCount]
, Coalesce( (Select Cast(v.low/1024.0 as float)
* SUM(a.used_pages - CASE WHEN a.type <> 1 THEN a.used_pages WHEN p.index_id < 2 THEN a.data_pages ELSE 0 END)
FROM sys.indexes as i
JOIN sys.partitions as p ON p.object_id = i.object_id and p.index_id = i.index_id
JOIN sys.allocation_units as a ON a.container_id = p.partition_id
Where i.object_id = tbl.object_id )
, 0.0) AS [IndexKB]
, Coalesce( (Select Cast(v.low/1024.0 as float)
* SUM(CASE WHEN a.type <> 1 THEN a.used_pages WHEN p.index_id < 2 THEN a.data_pages ELSE 0 END)
FROM sys.indexes as i
JOIN sys.partitions as p ON p.object_id = i.object_id and p.index_id = i.index_id
JOIN sys.allocation_units as a ON a.container_id = p.partition_id
Where i.object_id = tbl.object_id)
, 0.0) AS [DataKB]
, tbl.create_date, tbl.modify_date
FROM sys.tables AS tbl
INNER JOIN sys.indexes AS idx ON (idx.object_id = tbl.object_id and idx.index_id < 2)
INNER JOIN master.dbo.spt_values v ON (v.number=1 and v.type='E')
का आनंद लें।
जीयूआई से इसे कैसे करना है, इसके कई विवरण हैं।
रियल डीबीए का पता: जीयूआई चेंप्स के लिए है।
sp_helpdb
फ़ाइल के नाम, स्थान, डिस्क पर स्थान और प्रकार के सभी का एक रिकॉर्डसेट लौटाता है।
आप प्रत्येक डेटाबेस की sysfiles तालिका से फ़ाइल नाम भी प्राप्त कर सकते हैं।