我在这个 SQL Server (2005) 实例上可能有超过 100 个数据库。我想按照创建日期的顺序列出它们,或者更好的是,按照对任何表的最新修改日期的顺序列出它们。
是否有我可以编写的 SELECT 查询,同样重要的是,我在什么上下文中编写它以及执行它需要什么权限?
我在这个 SQL Server (2005) 实例上可能有超过 100 个数据库。我想按照创建日期的顺序列出它们,或者更好的是,按照对任何表的最新修改日期的顺序列出它们。
是否有我可以编写的 SELECT 查询,同样重要的是,我在什么上下文中编写它以及执行它需要什么权限?
您可以轻松地针对sys.databases
目录视图编写此查询
SELECT * FROM sys.databases
ORDER BY create_date
但不幸的是,我所知道的“最后修改日期”没有等价物......
这应该适用于该服务器上的任何数据库 - 无论您在哪个数据库中,这些sys
目录视图都应该可以从任何地方访问。
create table #db_name (db_name nvarchar(128), last_change datetime);
exec sp_MSForEachDB 'Use ?; insert into #db_name (db_name, last_change) select ''?'', max(modify_date) from sys.tables'
select * from #db_name order by last_change desc
这不完全是一种选择,但至少你得到了你想要的。我是我们其中一个数据库的 db_owner 并且在服务器范围内可能没有什么令人印象深刻的东西,所以它的要求不是很高。
这应该让你接近你想要的。
SELECT name, crdate
FROM master..sysdatabases