位置: 编程技术 - 正文

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行转列)

  • 股东向公司借款超过一年不还
  • 建筑发票一般开几个点
  • 计提个人部分保险
  • 应交税费待抵扣进项税额
  • 库存商品期末计量
  • 员工宿舍需要缴纳房产税么
  • 报表中利润为什么税后比税前大?
  • 工商营业执照变更流程
  • 同一笔销售业务的收入和成本
  • 职工福利费当年怎么扣
  • 收派服务发票需交税吗
  • 所得税报表怎么申报
  • 代扣代缴境外增值税可以抵扣
  • 打印的行程单可以删除吗
  • 母公司对子公司的控股比例
  • 折旧率通俗理解
  • 关闭通知横幅
  • 鸿蒙系统字体不太好看
  • 商业保险费包括哪些
  • 产品成本的计算过程也就是各种费用界限的划分过程
  • windows11ie
  • 收到股东垫付款的会计分录
  • php循环结构有哪几种语句
  • win10任务栏变成黑色
  • 明细账是什么样子
  • uniapp+uview
  • johnny kim宇航员
  • 带息应收票据应于收到或开出或承兑时
  • 阿卡迪亚国家公园景点
  • PHP:imagecolorexactalpha()的用法_GD库图像处理函数
  • 蒂内河畔圣艾蒂安小镇,法国阿尔卑斯省 (© CAVALIER Michel/hemis.fr/Alamy Stock Photo)
  • 伏尔塔瓦河上的纤夫
  • 资产负债表利润表的勾稽关系
  • uniapp开发微信小程序源代码
  • sql数据库语句基本语法
  • 支出的科目变化率怎么算
  • php自定义变量的方法是
  • ai复制命令
  • bounded linear functional
  • 低调低调
  • 残疾证哪里发
  • 包含个人社保的保险
  • 电脑自学网
  • 2022年我们国家将举行什么样的盛会
  • 建筑安装增值税纳税地点
  • MySQL默认字符集修改
  • 代扣款业务的处理方式
  • 公司制作横幅计入什么科目?
  • 必要报酬率和期望报酬率谁大更好
  • 税控服务费减免会计分录
  • 公司购买手表可以做费用吗?
  • 不动产计税金额
  • 技术服务费属于什么科目
  • 上年度多提财务费用
  • 低值易耗品属于资产类账户吗
  • 业务招待费可以开专票抵扣吗
  • 其他应付款在贷方表示什么
  • 建筑材料租赁公司
  • 生产成本里面的直接人工
  • 蔬菜公司开具专票可以抵扣吗
  • 将哪一linux文件系统引入
  • win8 设置
  • win8.1 应用商店是不是不能用了
  • linux配置文件命令
  • 日亚海淘官网
  • JavaScript的instanceof运算符学习教程
  • jquery 拖拽布局
  • 安卓作业仿银行
  • 脚本添加crontab
  • unity集成到app后变大了
  • node调试工具
  • angular.js
  • javascript产生随机数
  • JavaScript+html5 canvas制作的百花齐放效果完整实例
  • python 网络爬虫库
  • flask框架官方文档
  • javascript学习指南
  • 落实落地是什么意思
  • 什么是委托代征专用账户管理
  • 混凝土搅拌站如何结转成本
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设