SQL SERVER 将平凡查询的小表常驻内存

本文介绍如何使用SQL Server中的DBCC PIN TABLE和DBCC UNPIN TABLE命令来实现表的内存驻留与卸载,同时提供了检查表是否已驻留在内存中的方法。需要注意的是,不当使用这些命令可能会导致系统资源分配问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以下命令将表常驻内存:

 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,然后使表不驻留。驻留太多的表和驻留比高速缓存大的表会产生同样的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值