Atlanta Custom Software Development 

 
   Search        Code/Page
 

User Login
Email

Password

 

Forgot the Password?
Services
» Web Development
» Maintenance
» Data Integration/BI
» Information Management
Programming
  Database
Automation
OS/Networking
Graphics
Links
Tools
» Regular Expr Tester
» Free Tools

Get all user tables with size

Total Hit ( 1608)

Rate this article:     Poor     Excellent 

 Submit Your Question/Comment about this article

Rating


 


Returns User Tables by SIZE in DESCENDING ORDER
Add TOP n clause in SELECT to get selective results (i.e. TOP 10 TABLES)

Click here to copy the following block
declare @id    int            
declare @type    character(2)        
declare    @pages    int            
declare @dbname sysname
declare @dbsize dec(15,0)
declare @bytesperpage    dec(15,0)
declare @pagesperMB        dec(15,0)

create table #spt_space
(
   objid        int null,
   rows        int null,
   reserved    dec(15) null,
   data        dec(15) null,
   indexp        dec(15) null,
   unused        dec(15) null
)

set nocount on

-- Create a cursor to loop through the user tables
declare c_tables cursor for
select    id
from    sysobjects
where    xtype = 'U'

open c_tables

fetch next from c_tables
into @id

while @@fetch_status = 0
begin

   /* Code from sp_spaceused */
   insert into #spt_space (objid, reserved)
       select objid = @id, sum(reserved)
           from sysindexes
               where indid in (0, 1, 255)
                   and id = @id

   select @pages = sum(dpages)
           from sysindexes
               where indid < 2
                   and id = @id
   select @pages = @pages + isnull(sum(used), 0)
       from sysindexes
           where indid = 255
               and id = @id
   update #spt_space
       set data = @pages
   where objid = @id


   /* index: sum(used) where indid in (0, 1, 255) - data */
   update #spt_space
       set indexp = (select sum(used)
               from sysindexes
               where indid in (0, 1, 255)
               and id = @id)
             - data
       where objid = @id

   /* unused: sum(reserved) - sum(used) where indid in (0, 1, 255) */
   update #spt_space
       set unused = reserved
               - (select sum(used)
                   from sysindexes
                       where indid in (0, 1, 255)
                       and id = @id)
       where objid = @id

   update #spt_space
       set rows = i.rows
           from sysindexes i
               where i.indid < 2
               and i.id = @id
               and objid = @id

   fetch next from c_tables
   into @id
end

select    TableName = (select left(name,60) from sysobjects where id = objid),
   Rows = convert(char(11), rows),
   ReservedKB = ltrim(str(reserved * d.low / 1024.,15,0) + ' ' + 'KB'),
   DataKB = ltrim(str(data * d.low / 1024.,15,0) + ' ' + 'KB'),
   IndexSizeKB = ltrim(str(indexp * d.low / 1024.,15,0) + ' ' + 'KB'),
   UnusedKB = ltrim(str(unused * d.low / 1024.,15,0) + ' ' + 'KB')
       
from    #spt_space, master.dbo.spt_values d
where    d.number = 1
and    d.type = 'E'
order by reserved desc
drop table #spt_space
close c_tables
deallocate c_tables


Submitted By : Nayan Patel  (Member Since : 5/26/2004 12:23:06 PM)

Job Description : He is the moderator of this site and currently working as an independent consultant. He works with VB.net/ASP.net, SQL Server and other MS technologies. He is MCSD.net, MCDBA and MCSE. In his free time he likes to watch funny movies and doing oil painting.
View all (893) submissions by this author  (Birth Date : 7/14/1981 )


Home   |  Comment   |  Contact Us   |  Privacy Policy   |  Terms & Conditions   |  BlogsZappySys

© 2008 BinaryWorld LLC. All rights reserved.