sys.master_files和sys.
database_files有什么区别?我的实例中有大约20个数据库,但是当我查询sys.master_files时,我没有收到任何行.为什么?当我查询sys.database_files时,我获得有关当前数据库的数据库文件的信息.
解决方法
sys.master_files:
Contains a row per file of a database
as stored in the master database. This
is a single,system-wide view.
Contains a row per file of a database as stored in the database itself. This is a per-database view.
因此,SELECT * FROM sys.master_files应列出实例中每个数据库的文件,而SELECT * FROM sys.database_files应列出特定数据库上下文的文件.
在这里测试(sql 2K8),它按照上面的方式工作?
更新:
如果您没有看到sys.master_files中的行,则可能是BOL声明的权限问题:
The minimum permissions that are
required to see the corresponding row
are CREATE DATABASE,ALTER ANY
DATABASE,or VIEW ANY DEFINITION.
而sys.database_files只需要公共角色的成员资格.