18

我在这个 SQL Server (2005) 实例上可能有超过 100 个数据库。我想按照创建日期的顺序列出它们,或者更好的是,按照对任何表的最新修改日期的顺序列出它们。

是否有我可以编写的 SELECT 查询,同样重要的是,我在什么上下文中编写它以及执行它需要什么权限?

4

3 回答 3

33

您可以轻松地针对sys.databases目录视图编写此查询

SELECT * FROM sys.databases
ORDER BY create_date 

但不幸的是,我所知道的“最后修改日期”没有等价物......

这应该适用于该服务器上的任何数据库 - 无论您在哪个数据库中,这些sys目录视图都应该可以从任何地方访问。

于 2013-09-18T15:25:08.507 回答
3
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 并且在服务器范围内可能没有什么令人印象深刻的东西,所以它的要求不是很高。

于 2013-09-18T15:56:17.320 回答
2

这应该让你接近你想要的。

SELECT name, crdate 
FROM master..sysdatabases
于 2013-09-18T15:25:28.793 回答