验证 SQL Server 中检查器工作空间的 FileGroup 存储

确保工作空间创建于正确的文件组下,从而可以进行适当的数据存储并减缓磁盘争用情况。使用之前修改的 DBTUNE 配置,可在 SQL Server Management Studio 中运行以下脚本示例。

设置当前数据库。

USE REVDB
GO

在特定数据库中列出所有 FileGroup 和数据文件。

EXEC sp_helpdb revdb
GO

列出特定 FileGroup 的数据文件。在本例中,将列出 PRIMARY FileGroup 数据文件。

EXEC sp_helpfilegroup 'PRIMARY'
GO

按 FileGroup 列出表。

SELECT USER_NAME(o.uid) [Owner],
 OBJECT_NAME(i.id) [Table Name], 
 FILEGROUP_NAME(groupid) AS [Filegroup Name]
 FROM sysindexes i inner join sysobjects o
 ON i.id = o.id
 WHERE i.indid IN (0, 1) AND OBJECTPROPERTY(i.id, 'IsMSShipped') = 0 AND
 USER_NAME(o.uid) = 'rev' 
 ORDER BY 1,3,2
GO

按表和 FileGroup 列出索引。

select 'owner'=user_name(o.uid) 
,'table_name'=object_name(i.id),i.indid
,'index_name'=i.name ,i.groupid
,'filegroup'=f.name ,'file_name'=d.physical_name
,'dataspace'=s.name from sys.sysindexes i
,sys.sysobjects o,sys.filegroups f 
,sys.database_files d, sys.data_spaces s
where objectproperty(i.id,'IsUserTable') = 1
and i.id = o.id
and f.data_space_id = i.groupid
and f.data_space_id = d.data_space_id
and f.data_space_id = s.data_space_id
and user_name(o.uid) = 'rev'
order by object_name(i.id),i.name,f.name
GO

如果任何表或索引存储在错误的文件组中,可使用 ALTER TABLE 和 ALTER INDEX 来更改文件组(请参阅《SQL Server 联机丛书》,网址为 http://msdn.microsoft.com/en-us/library/ms130214.aspx)。

在 SQL Server Management Studio 中,还可以重新创建表和索引的 DDL 脚本,然后可以在创建脚本 中修改文件组参数并在正确的文件组中重新创建表和索引。在表为空且允许重新创建数据库对象时,此操作尤其有用。

9/9/2014