SQL Server:sys.master_files与sys.database_files

时间:2010-11-13 20:26:37

标签: sql-server database sql-server-2005 sql-server-2008

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

1 个答案:

答案 0 :(得分:6)

sys.master_files

  

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

sys.database_files

  

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

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

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

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

  

最低权限   需要查看相应的行   是创建数据库,不管是什么   数据库,或查看任何定义。

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