位置: 编程技术 - 正文

SQL Server里书签查找的性能伤害(sqlserver经典书籍)

编辑:rootadmin

推荐整理分享SQL Server里书签查找的性能伤害(sqlserver经典书籍),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql 标签,sqlserver经典书籍,sqlserver经典书籍,sqlserver经典书籍,sql server 书,sql 标签,sqlserver经典书籍,sql server 电子书,内容如对您有帮助,希望把文章链接给更多的朋友!

在我的博客上,以前我经常谈到SQL Serverl里的书签查找,还有它们带来的很多问题。在今天的文章里,我想从性能角度进一步谈下书签查找,还有它们如何拉低你整个SQL Server性能。

书签查找——反复循环

如果你的非聚集索引不是个覆盖非聚集索引,SQL Server的查询优化器会引入书签查找。对于从非聚集索引你返回的每一行,SQL Server需要在聚集索引里或堆表里进行额外的查找操作。

例如当你的的聚集索引包含3层,为了返回必要的信息,对于每一行,你需要3页额外的读取。因此,查询优化器再执行计划里选择书签查找操作,仅在有意义的时候发生——基于你查询的选择度。下图展示了有书签查找操作的执行计划。

通常人们不会太关注书签查找,因为它们只执行几次。如果你的查询选择度太低,查询优化器会用聚集索引扫描或表扫描运算符直接扫描整个表。但只在SQL Server重用缓存的执行计划,这个计划是有多次不同运行值,包含书签查找的(基于最初提供的输入值),因此这个情况很容易发生,书签查找反复执行。

为了演示这个性能问题,接下来的查询我指定查询优化器使用特定的非聚集索引。查询本身返回行,因为对于每个查询执行,SQL Server需要进行书签查找次——反复执行。

SQL Server里书签查找的性能伤害(sqlserver经典书籍)

下图展示了查询执行后的实际执行计划。

执行计划看起来非常恐怖(查询优化器甚至启用了并行计划!),因为书签查找运算符这里执行了次,查询本身产生了超过个逻辑读!(逻辑读个数可以从STATISTIC IO里获取)。

接下来向你展示下,当你有很多并行用户执行这个糟糕查询时,SQL Server会发生什么。我会使用ostress.exe(RML工具的一部分)来模拟个并行用户的查询。

ostress.exe -Q”EXEC BookmarkLookupsPerformance.dbo.RetrieveData” -n -q

在我的测试系统上花费了近秒来完成个并行查询。在此期间,CPU占用很高,因为SQL Server需要嵌套循环运算符来进行书签查找操作。嵌套循环操作当然很占CPU资源。

现在让我们修改索引设计,为这个查询创建覆盖非聚集索引。有了非聚集索引,查询优化器不需要再执行计划里进行书签查找。一个非聚集索引查找就可以返回同样的结果:

这次当我们再次用ostress.exe执行同个查询,我们看到每个查询在5秒内完成。和我们刚才看到的秒有很大的区别。这就是覆盖非聚集索引的威力:在我们查询里气门请求的数据都可以在非聚集索引里直接找到,因此书签查找就可以避免。

小结

在这个文章里我向你展示了不好的书签查找会伤及性能。因此,对于重要的查询快速完成查询非常重要——而使用并行的书签查找的执行计划并不是好的选择。这里覆盖非聚集索引可以帮到你。下次设计索引时可以考虑下这个方法。

标签: sqlserver经典书籍

本文链接地址:https://www.jiuchutong.com/biancheng/324373.html 转载请保留说明!

上一篇:SqlServer快速检索某个字段在哪些存储过程中(sql 语句)(sql怎么搜索表)

下一篇:SQL Server行转列的方法解析(SQLserver行转列)

  • 需要出口
  • 印花税的征税对象是条例列举的凭证未列举的不征税
  • 劳务费个人所得税由谁申报
  • 公司缴纳养老保险不在个人账户里吗
  • 用友t3采购订单怎么录入
  • 收据怎么粘贴在费用报销单上
  • 汇算清缴现金流量表怎么填
  • 个体每月开票超10万
  • 银行打出的明细清单怎么看不懂
  • 什么情况可以减免税收
  • 利得和损失计入所有者权益
  • 用于展览的存货如何做会计处理?
  • 购进机器进项税额怎么核算?
  • 进口后的技术服务费
  • 开票系统里的开户行可以更改吗
  • 年报填写中,认缴出资时间怎么填?
  • 金蝶年结后发现错误怎么办
  • 小微企业增值税税率
  • 企业所得税预缴税款表怎么填
  • 特种设备培训费计入什么会计科目
  • 期间费用企业所得税扣除
  • win11系统进程
  • 开办费 工资
  • 认证超时什么意思
  • win11任务栏失灵
  • 毛利率计算公式举例说明
  • 公司债务转移的法律规定
  • linux tr
  • 微软windows11正式版下载
  • 查账补交以前年度印花税分录
  • 迷迭香的养殖方法
  • 技术股如何分红交易
  • 衡量一个企业经营状况
  • 亏损销售怎么结转库存成本怎么计算
  • 如何使用wireshark抓取HTTP数据包?
  • Mont Choisy Beach, Mauritius (© Robert Harding World Imagery/Offset by Shutterstock)
  • 圣克鲁斯岛战役
  • 房屋所在地的房子怎么查
  • 西部大开发的主要政策措施是什么?
  • 保险公司赔付进项税
  • id3决策树伪代码
  • 计提租金怎么做会计分录
  • 免征增值税怎么入账
  • python统计字符串长度
  • 企业产值用什么符号表示
  • 织梦添加文章如何修改高级参数
  • cms采集网站
  • 帝度官网 说明书
  • Building a HTTP Proxy
  • 递延收益为什么是递延所得税资产
  • 虚开发票是指怎样?
  • sql2000日志清理
  • 公转私户违法吗
  • 房地产企业拆迁补偿费入账要求
  • 通货紧缩的影响简答题
  • 暂估入库的商品能出库吗
  • 哪些发票不能用
  • 股权转让如何进行资产评估的
  • 4s店出售试驾车账务处理
  • 超市发票报销一般写什么明细
  • MySql insert插入操作的3个小技巧分享
  • 用SQL统计SQLServe表存储空间大小的代码
  • 数据库时区与url连接设置的时区
  • Sqlserver聚集索引和非聚集索引的区别
  • mac安装surge
  • linux 的ll
  • 微软停止对xp的操作
  • 怎么删除swapfile
  • 快速关机的快捷方式
  • win10电源选项
  • nodejs回调函数返回值如何传递给其它函数
  • nodejs安装在c盘好还是d盘好
  • jQuery实现ajax调用WCF服务的方法(附带demo下载)
  • ssh执行远程命令 参数
  • mac怎么编写python
  • python 字典的字典
  • 小规模纳税人销售额怎么算
  • uk在哪里看开票截止日期
  • 大乐透中奖查询走势图
  • 宁波购房契税退税条件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设