位置: 编程技术 - 正文

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

  • 为什么税务申报要补缴
  • 已抵扣的进项税额怎么转出
  • 稳岗返还资金最新账务处理
  • 税前扣除什么意思
  • 企业发生的哪些成本可以在企业所得税税前扣除
  • 更换税控盘后原发票如何导入旧盘开票税局
  • 个税隔一个月没申报这个月可以补上吗
  • 个人所得税申报错误如何更正申报
  • 哪些邮政业务可以寄快递
  • 门诊药房主要业务
  • 进项抵扣怎么操作
  • 原材料的运输费怎么做会计分录
  • 营改增对运输业的影响
  • 固定资产叉车卖出怎么开票
  • 车船税提高了吗
  • 加工费月底需要全部结转吗
  • 成本费用总额包括信用减值损失吗
  • 建筑安装服务费可以抵扣进项税吗
  • win10如何禁用administrator用户
  • macbook如何安装
  • 如何界定企业的收益
  • 0x0000000a蓝屏代码怎么解决
  • php单双引号的区别
  • win10怎么设置硬盘为第一启动项
  • mmc.exe是什么进程
  • 民间非营利组织会计账务处理
  • macbook直接显示桌面
  • php定时执行代码
  • 存货包括哪些会计账户
  • 自费出版的书籍可以售卖吗
  • LNMP部署laravel以及xhprof安装使用教程
  • 生产性生物资产折旧计入什么科目
  • 直接材料成本差异账户在平时登记贷方登记
  • php错误和异常
  • 浅谈php中变量的使用情况
  • php数据的提交与采集实验报告
  • c#创建web
  • ps去水印的三种方法
  • 材料暂估入账
  • python获取值对应的键
  • 为什么开发票能抵税
  • 固定资产家具用具包括什么
  • 出售无形资产净收益计入什么科目
  • 增值税年底抵扣
  • 教育类财务工作内容
  • 公司能经营烟草公司吗
  • mysql数据库优化配置
  • linux环境中使用哪些搜索命令比find更高效
  • 财政拨入的专项款专账怎么做
  • 取得异常凭证企业所得税调整
  • 收到上年度企业所得税退税怎么做账
  • 暂估入库一直没有发票
  • 工程已完工未开发票确认收入吗
  • 某项租赁合同,租赁期为8年,每年年末支付租金100万
  • windows8禁用uac
  • ubuntu无法下载
  • Ubuntu系统怎么设置root
  • hosts文件位置在哪
  • linux进程详解
  • win7系统防火墙无法关闭
  • win7系统使用ituns设置iphone铃声图文教程
  • js闭包的理解详解
  • 使用jquery操作dom
  • 如何在eclipse
  • perl的chomp
  • dom教程
  • 关于中国天气的新闻报道
  • javascript的描述
  • android Lollipop(5.0)--touch feedback(触摸反馈)
  • 创建shell脚本命令
  • pythen开发环境
  • jquery设置单选框
  • Cannot run program "/home/mohemi/Program/adt-bundle-linux-x86_64-20130729/sdk//tools/emulator": erro
  • 发票为什么要验旧操作
  • 邮政银行开税票要什么材料
  • 地税局收税标准
  • 社保扣费为什么忽高忽低
  • 福建税务局电子税务局电话多少
  • 个人所得税怎么申报
  • 深圳国税税发票在哪里开
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设