如果是要得到数据库中所有表的条数呢?我们来看几种最常见的方式:
--方法一
select b.name as tablename , c.row_count as datacount from sys.indexes a , sys.objects b , sys.dm_db_partition_stats c where a.[object_id] = b.[object_id] AND b.[object_id] = c.[object_id] AND a.index_id = c.index_id AND a.index_id < 2 AND b.is_ms_shipped = 0
--方法二
select b.name as tablename , a.rowcnt as datacount from sysindexes a , sysobjects b where a.id = b.id and a.indid < 2 and objectproperty(b.id, 'IsMSShipped') = 0
--方法三
if exists ( select * from dbo.sysobjects where id = object_id(N'[dbo].[TableSpace]') and objectproperty(id, N'IsUserTable') = 1 ) drop table [dbo].[TableSpace] go create table TableSpace ( TableName varchar(20) , RowsCount char(11) , Reserved varchar(18) , Data varchar(18) , Index_size varchar(18) , Unused varchar(18) ) go declare @sql varchar(500) declare @TableName varchar(20) declare mCursor cursor for select name from sysobjects where xtype='U' open mCursor fetch NEXT from mCursor into @TableName while @@fetch_status = 0 begin set @sql = 'insert into TableSpace ' set @sql = @sql + ' exec sp_spaceused ''' + @TableName + ''' ' exec (@sql) fetch NEXT from mCursor into @TableName end close mCursor deallocate mCursor go --显示结果 select TableName,RowsCount from TableSpace
--建议使用后两种方式,对于SQL SERVER 2005来说,三种方法都好使,如果是其他板本,可以逐一测试一下。
方法四
--==========================================================================
-- 说明: 本脚本用于查询当前数据库中所有表格的记录条数
-- 并将结果存入tableinfo表中,不会删除以备用户再做处理与分析
-- 不过,最后请用户删除此表。
--==========================================================================
if exists (select * from dbo.sysobjects where id = object_id(n[dbo].[tablespace]) and objectproperty(id, nisusertable) = 1) drop table [dbo].[tablespace] go create table tablespace ( tablename varchar(20), rowscount char(11), reserved varchar(18), data varchar(18), index_size varchar(18), unused varchar(18) ) go declare @sql varchar(500) declare @tablename varchar(20) declare cursor1 cursor for select name from sysobjects where xtype=u open cursor1 fetch next from cursor1 into @tablename while @@fetch_status = 0 begin set @sql = insert into tablespace set @sql = @sql + exec sp_spaceused + @tablename + exec (@sql) fetch next from cursor1 into @tablename end close cursor1 deallocate cursor1 go --显示结果 select * from tablespace --order by tablename --order by tablename asc --按表名称,用于统计表 --order by rowscount desc --按行数量,用于查看表行数 --order by reserved desc, data desc --按占用空间 --order by index_size desc, reserved desc --按索引空间查看 go --查看库的使用状况,可以随时执行的。 --exec sp_spaceused --go