如何在同一个查询中同时使用 sp_msforeachtable 和 sp_msforeachdb?

Mic*_*ael 5 sql-server sp-msforeachdb sql-server-2008 sp-msforeachtable

有什么方法可以引用在“sp_msforeachdb”循环内运行的“sp_MSforeachtable”循环内的表?

例如,在以下查询中,'?' 总是引用数据库:

DECLARE @cmd VARCHAR(8000);

SET @cmd = 'USE ?; EXEC sp_MSforeachtable @command1="select db_name = DB_NAME(), db_foreach = ''?'', tb_foreach = ''?'' "'

EXEC sp_msforeachdb @command1 =@cmd
Run Code Online (Sandbox Code Playgroud)

导致:

 db_name        db_forearch    tb_foreach
 ServerMonitor  master         master
Run Code Online (Sandbox Code Playgroud)

我想要一些类似的东西:

 db_name        db_forearch    tb_foreach
 ServerMonitor  master         <TABLE_NAME>
Run Code Online (Sandbox Code Playgroud)

我应该改变什么?


解决了。按照肖恩的建议,我使用了我的 ow 光标。但是 Ben Thul 建议的 @replacechar 解决方案正是我正在寻找的。

DECLARE @cmd VARCHAR(8000);

SET @cmd = 'USE ^; EXEC sp_MSforeachtable @command1="select db_name = DB_NAME(), db_foreach = ''^'', tb_foreach = ''?'' "'

EXEC sp_msforeachdb @command1 =@cmd, @replacechar = '^'
Run Code Online (Sandbox Code Playgroud)

Ben*_*hul 3

查看 sp_msforeachtable 的参数。其中之一是@replacechar,默认情况下,它是一个问号(即?)。请随意传递另一个同样不可能出现在查询中的字符(可能是 ^)。

当然,如果我没有提到这取决于你想要做什么(我认为你想要在所有表上做的任何事情都是可以通过这种方式完成的),那么我就失职了,有更简单的方法在 powershell 中读取(和写入)解决方案:

import-module sqlps -disablenamechecking;
$s = new-object microsoft.sqlserver.management.smo.server '.';
foreach ($db in $s.databases) {
   foreach ($table in $db.Tables) {
      $table | select parent, name; --merely list the table and database
   }
}
Run Code Online (Sandbox Code Playgroud)