以下命令将表常驻内存:
DECLARE @db_id int, @tbl_id int
USE 盛京时报
SET @db_id = DB_ID('盛京时报')
SET @tbl_id = OBJECT_ID('盛京时报..T_UIInfo')
DBCC PINTABLE (@db_id, @tbl_id)
将表从内存卸载
DBCC UNPINTABLE (@db_id, @tbl_id)
查询表是否常驻内存
select objectproperty(@tbl_id'tableispinned')
注意 DBCC PINTABLE 可以提供性能改进,但是使用时务必小心。如果驻留大表,则该表在开始时会使用一大部分高速缓存,而不为系统中的其它表保留足够的高速缓存。如果所驻留的表比高速缓存大,则该表会填满整个高速缓存。sysadmin 固定服务器角色的某个成员必须关闭而后重新启动 SQL Server,然后使表不驻留。驻留太多的表和驻留比高速缓存大的表会产生同样的问题。
本文介绍如何使用SQL Server中的DBCC PIN TABLE和DBCC UNPIN TABLE命令来实现表的内存驻留与卸载,同时提供了检查表是否已驻留在内存中的方法。需要注意的是,不当使用这些命令可能会导致系统资源分配问题。
1704

被折叠的 条评论
为什么被折叠?



