微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver sp_msforeachtable用法

 

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,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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐