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时,我获得有关当前数据库的数据库文件的信息.
包含存储在master数据库中的每个数据库文件的行.这是一个单一的系统范围视图.
包含存储在数据库本身中的每个数据库文件的行.这是每个数据库视图.
因此,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只需要公共角色的成员资格.
| 归档时间: |
|
| 查看次数: |
11018 次 |
| 最近记录: |