日期:2014-05-18  浏览次数:20528 次

SQL查询,想查询服务器上的所有数据库,然后数据库对应表的数量。
如题:
大概这样的格式
数据库名称 表数量
dome1 100
dome2 200

------解决方案--------------------
SQL code

--查看所有数据库:
select  name from sys.databases
--查看当前数据库的所有表的名字
select name from sysobjects where xtype='U' and category=0

------解决方案--------------------
SQL code
DECLARE @T TABLE(DBName sysname,TabCount int)
INSERT @T EXEC sp_msforeachdb 'select ''?'',count(*)  FROM ?.sys.tables WHERE type=''U'''

SELECT * FROM @T

------解决方案--------------------
SQL code

--查看当前数据库的所有表
declare @str varchar(max)
set @str=''
select @str=@str+' use '+name+
' select '+quotename(name,'''')+' as databasename,COUNT(name) as [count] 
from sysobjects where xtype=''U'' and category=0'
from (select  name from sys.databases)a
print @str
exec(@str)
--本机测试结果
databasename    count
master    124
databasename    count
tempdb    6
databasename    count
model    0
databasename    count
msdb    17

------解决方案--------------------
探讨
SQL code

DECLARE @T TABLE(DBName sysname,TabCount int)
INSERT @T EXEC sp_msforeachdb 'select ''?'',count(*) FROM ?.sys.tables WHERE type=''U'''

SELECT * FROM @T