sqlserver sp_msforeachtable用法

来源:互联网 发布:w10打开软件防火墙 编辑:程序博客网 时间:2024/05/22 01:41

 

1、     输出当前的用户所有的表

 
   sp_msforeachtable
  @command1="print '?'"

 

    

2、    查询数据所有的表和表中的记录数

  

sp_msforeachtable
@command1="select '?' as 表名,count(*) as 记录数 from ?"

 

 

3、   数据库所有表中的ABC列,换成123

 

exec   sp_msforeachtable   @command1=N'  
declare   @s   nvarchar(4000),@tbname   sysname  
select   @s=N'''',@tbname=N''?''  
select   @s=@s+N'',''+quotename(a.name)+N''=replace(''+quotename(a.name)+N'',N''''ABC'''',N''''123'''')''  
from   syscolumns   a,systypes   b  
where   a.id=object_id(@tbname)    
and   a.xusertype=b.xusertype  
and   b.name   like   N''%char''  
if   @@rowcount>0  
begin  
set   @s=stuff(@s,1,1,N'''')  
print(N''update  
''+@tbname+''   set   ''+@s)  

exec(N''update   ''+@tbname+''   set   ''+@s)  
end'  

 

 

4、查询数据库每个表的空间利用情况

 

 

set nocount on
exec sp_MSForEachTable
@precommand=N'
create table ##(
id int identity,
表名 sysname,
字段数 int,
记录数 int,
保留空间 Nvarchar(10),
使用空间 varchar(10),
索引使用空间 varchar(10),
未用空间 varchar(10))',
@command1=N'insert ##(表名,记录数,保留空间,使用空间,索引使用空间,未用空间) exec sp_spaceused ''?''
        update ## set 字段数=(select count(*) from syscolumns where id=object_id(''?'')) where id=scope_identity()',
@postcommand=N'select * from ## order by 记录数 desc drop table ##'
set nocount off

 

 

原创粉丝点击