sys.master_files和sys.database_files有什么区别?我的实例中有大约20个数据库但是当我查询sys.master_files时,我没有收到任何行。为什么?当我查询sys.database_files时,我得到有关当前数据库的数据库文件的信息。
答案 0 :(得分:6)
每个数据库文件包含一行 存储在master数据库中。这个 是一个单一的系统范围的视图。
包含存储在数据库本身中的每个数据库文件的行。这是一个按数据库视图。
因此,SELECT * FROM sys.master_files
应列出实例中每个数据库的文件,而SELECT * FROM sys.database_files
应列出特定数据库上下文的文件。
在这里测试(SQL 2K8),它按照上面的方式工作?
<强>更新强> 如果您没有看到sys.master_files中的行,则可能是BOL声明的权限问题:
最低权限 需要查看相应的行 是创建数据库,不管是什么 数据库,或查看任何定义。
而sys.database_files只需要公共角色的成员资格。