SQL Server执行SQL语句时内存占用特点
2007-11-11 11:36:09 来源:WEB开发网核心提示: ·SQL高手篇:精妙SQL语句介绍·一个sql语句,包含有几乎所有标准查询·经验分享交流:常用SQL语句技法·SQL语句和存储过程 查询语句的流程控·实战SQL语句收集(不断更新中--)·SQL语句性能优化--LECCO SQL Ex
- ·SQL高手篇:精妙SQL语句介绍
·一个sql语句,包含有几乎所有标准查询
·经验分享交流:常用SQL语句技法
·SQL语句和存储过程 查询语句的流程控
·实战SQL语句收集(不断更新中--)
·SQL语句性能优化--LECCO SQL Expert
·查询同一表内多字段同时重复记录的SQL
·数据库人员手边系列:SQL语句导入导出
·得出SQL语句的执行时间的方法
·使用一条SQL语句删除表中重复记录
修改表结构,在MobileNo字段上建立聚集索引。然后再次执行刚才的SQL语句。得到的执行计划变为聚集索引扫描。IO统计消息为:
(1000 row(s) affected)
表'P_User'。扫描计数1,逻辑读取6 次,物理读取1 次,预读4 次,lob 逻辑读取0 次,lob 物理读取0 次,lob 预读0 次。
这里的逻辑读取变为6次。
内存情况如下:
(WINDOWS平台上强大的数据库平台)执行SQL语句时内存占用特点(图二)" width="500" height="78" />
内存中的变化是增加了一个非叶级的聚集索引页,而叶级的聚集索引则会和数据放在一起。
另外,可以查看该表索引的级别:
以下是引用片段: SELECT database_id,object_id,index_id,index_level,page_count,record_count FROM sys.dm_db_index_physical_stats (DB_ID(N'TestGDB'), OBJECT_ID(N'dbo.P_User'), NULL, NULL , 'DETAILED'); |
从结果可以看到该表的聚集索引总共分2级。
(WINDOWS平台上强大的数据库平台)执行SQL语句时内存占用特点(图三)" width="444" height="66" />
因而逻辑读增加了2——(由于发生Clustered Index Scan,除了根级别的聚集索引页占用1次外,从根级别聚集索引定位到叶级别的聚集索引也将额外占用1次逻辑读)。
另外一个变化是只发生了一次物理读,即读取根级别的聚集索引页,另外4个数据页则通过预读方式而不是物理读从磁盘装入内存Buffer。这使得有聚集索引的情况下,执行SQL所直接花费的代价实际上更小。
2.2 执行高选择性选取
在建立聚集索引情况下,对性能有益的变化是:
对于Select Top 1 * From P_Order 或者Select * From P_Order Where MobileNo=28702这样的语句,在有聚集索引情况下,只会将最终记录所在的页读入内存。
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
- ››SQL SERVER无法安装成功,sqlstp.log文件提示[未发...
- ››Sql Server中通过父记录查找出所有关联的子记录
- ››SqlServer触发器、存储过程和函数
- ››SQL Server 中的事务(含义,属性,管理)
- ››Sqlite数据库插入和读取图片数据
- ››Sql server 2005拒绝了对对象 'xx表' (数...
- ››Sql server 2005拒绝了对对象 'xx表' (数...
更多精彩
赞助商链接