SQL Server:sys.master_files与sys.database_files

juu*_*uur 8 database sql-server sql-server-2005 sql-server-2008

sys.master_files和sys.database_files有什么区别?我的实例中有大约20个数据库但是当我查询sys.master_files时,我没有收到任何行.为什么?当我查询sys.database_files时,我获得有关当前数据库的数据库文件的信息.

Ada*_*Dev 7

sys.master_files:

包含存储在master数据库中的每个数据库文件的行.这是一个单一的系统范围视图.

sys.database_files:

包含存储在数据库本身中的每个数据库文件的行.这是每个数据库视图.

因此,SELECT * FROM sys.master_files应列出实例中每个数据库的文件,而SELECT * FROM sys.database_files应列出特定数据库上下文的文件.

在这里测试它(SQL 2K8),它按照上面的方式工作?

更新: 如果您没有看到sys.master_files中的行,则可能是BOL声明的权限问题:

查看相应行所需的最小权限是CREATE DATABASE,ALTER ANY DATABASE或VIEW ANY DEFINITION.

而sys.database_files只需要公共角色的成员资格.