分析MSSQL数据库的用户表数和记录数 (转载)

create procedure sp_tableCount
@newTable varchar(50),--new create table name
@isSet int            --whether return new table recordset,non 0--return
as
declare @TableName nvarchar(100);
declare @sql nvarchar(800)

SET NOCOUNT ON
----create a target table named @newTable param value--------
IF EXISTS (SELECT table_name FROM INFORMATION_SCHEMA.TABLES
      WHERE table_name = @newTable)
   exec('DROP TABLE '+@newTable)
-----create target table------------
set @sql='create table ' + @newTable + '
(
  Categary nvarchar(100) not null,
  Value    int
)'
exec(@sql) 

----------add user tables count into target table----------------
set @sql='insert into '+@newTable+' select ''User Tables'',count(*)-1  from sysobjects where type=''U'''
exec(@sql)

--------define a cursor pointing the user tablename recordset--------
declare TableName_Cursor CURSOR FOR
select name  from sysobjects where  type='U'and name<>@newTable


open TableName_Cursor

fetch next from TableName_Cursor into @TableName

-------append every user table recordcount to target table----------------
while @@Fetch_Status=0
begin
  set @sql='insert into '+@newTable+' select N'''+@TableName+''',count(*) from '  + @TableName
  exec(@sql)


  fetch next from TableName_Cursor into @TableName
end

-------release  resource occupied by TableName_Cursor --------
close TableName_Cursor
deallocate TableName_Cursor

--------deal with the @isSet param-----------------
if @isSet<>0
exec('select * from '+@newTable)

posted @ 2008-10-13 11:47  昕友软件开发  阅读(350)  评论(0编辑  收藏  举报
欢迎访问我的开源项目:xyIM企业即时通讯