查看SqlServer的内存使用情况
2015-06-26 17:37
423 查看
上一篇提到动态T-SQL会产生较多的执行计划,这些执行计划会占用多少内存呢?今天从徐海蔚的书中找到了答案。动态视图不仅可以查到执行计划的缓存,数据表的页面缓存也可以查到,将SQL整理一下,做个标记。
-- 查询SqlServer总体的内存使用情况 select type , sum(virtual_memory_reserved_kb) VM_Reserved , sum(virtual_memory_committed_kb) VM_Commited , sum(awe_allocated_kb) AWE_Allocated , sum(shared_memory_reserved_kb) Shared_Reserved , sum(shared_memory_committed_kb) Shared_Commited --, sum(single_pages_kb) --SQL2005、2008 --, sum(multi_pages_kb) --SQL2005、2008 from sys.dm_os_memory_clerks group by type order by type -- 查询当前数据库缓存的所有数据页面,哪些数据表,缓存的数据页面数量 -- 从这些信息可以看出,系统经常要访问的都是哪些表,有多大? select p.object_id, object_name=object_name(p.object_id), p.index_id, buffer_pages=count(*) from sys.allocation_units a, sys.dm_os_buffer_descriptors b, sys.partitions p where a.allocation_unit_id=b.allocation_unit_id and a.container_id=p.hobt_id and b.database_id=db_id() group by p.object_id,p.index_id order by buffer_pages desc -- 查询缓存的各类执行计划,及分别占了多少内存 -- 可以对比动态查询与参数化SQL(预定义语句)的缓存量 select cacheobjtype , objtype , sum(cast(size_in_bytes as bigint))/1024 as size_in_kb , count(bucketid) as cache_count from sys.dm_exec_cached_plans group by cacheobjtype, objtype order by cacheobjtype, objtype -- 查询缓存中具体的执行计划,及对应的SQL -- 将此结果按照数据表或SQL进行统计,可以作为基线,调整索引时考虑 -- 查询结果会很大,注意将结果集输出到表或文件中 SELECT usecounts , refcounts , size_in_bytes , cacheobjtype , objtype , TEXT FROM sys.dm_exec_cached_plans cp CROSS APPLY sys.dm_exec_sql_text(plan_handle) ORDER BY objtype DESC ; GO
相关文章推荐
- ORACLE数据库中查找用户、角色、权限的SQL汇总(转发)
- MySQL锁定状态查看命令
- 【整理】MySQL引擎
- 安装Memcache的PHP扩展
- MySQL事务隔离级别详解
- spring+redis整合入门
- SQLServer2008把数据导出成可执行的sql脚本
- SQL Server中字符串函数LEN 和 DATALENGTH辨析
- MyBatis单一和批量操作数据库SQL
- [MyBatis]获取数据库连接、批量执行SQL语句
- SQL数据库——计算列
- sql server 常见错误代码15000 - 15999含义解析
- Oracle基础学习登陆SQLPLUS(一)
- Sql入门------数据库事务
- yum安装mysql后没有mysqld
- SQL Server 日志清理
- 安卓数据存储之SQLLite
- mysql5.6.25的zip格式安装配置
- hbase vs mongodb
- Oracle 进程结构