位置: 编程技术 - 正文

SQLSERVER如何查看索引缺失及DMV使用介绍(sqlserver如何查看操作日志)

编辑:rootadmin

当大家发现数据库查询性能很慢的时候,大家都会想到加索引来优化数据库查询性能,但是面对一个复杂的SQL语句,找到一个优化的索引组合对人脑来讲,真的不是一件很简单的事。

好在SQLSERVER提供了两种“自动”功能,给你建议,该怎么调整索引

第一种是使用DMV

第二种是使用DTA (database engine tuning advisor) 数据库引擎优化顾问

这篇文章主要讲第一种

从SQL以后,在SQLSERVER对任何一句语句做编译的时候,都会去评估一下,

这句话是不是缺少什么索引的支持,如果他认为是,他还会预估,如果有这麽一个索引

他的性能能提高多少

SQLSERVER有几个动态管理视图

sys.dm_db_missing_index_details

sys.dm_db_missing_index_groups

sys.dm_db_missing_index_group_stats

sys.dm_db_missing_index_columns(index_handle)

sys.dm_db_missing_index_details

这个DMV记录了当前数据库下所有的missing index的信息,他针对的是SQLSERVER从启动以来所有运行的语句,

而不是针对某一个查询。DBA可以看看,哪些表格SQLSERVER对他是最有“意见”的

以下是这个DMV的各个字段的解释:

1、index_handle:标识特定的缺失索引。该标识符在服务器中是唯一的。index_handle 是此表的密钥

2、database_id :标识带有缺失索引的表所驻留的数据库

3、object_id :标识索引缺失的表

4、equality_columns:构成相等谓词的列的逗号分隔列表 即哪个字段缺失了索引会在这里列出来(简单来讲就是where 后面的筛选字段),

谓词的形式如下:table.column =constant_value

5、inequality_columns :构成不等谓词的列的逗号分隔列表,例如以下形式的谓词:table.column > constant_value “=”之外的任何比较运算符都表示不相等。

6、included_columns:用于查询的涵盖列的逗号分隔列表(简单来讲就是 select 后面的字段)。

7、statement:索引缺失的表的名称

比如下面这个查询结果

那么应该创建这样的索引在ProductID上创建索引,SalesOrderID作为包含性列的索引

注意事项:

由 sys.dm_db_missing_index_details 返回的信息会在查询优化器优化查询时更新,因而不是持久化的。

缺失索引信息只保留到重新启动 SQL Server 前。如果数据库管理员要在服务器回收后保留缺失索引信息,

则应定期制作缺失索引信息的备份副本

sys.dm_db_missing_index_columns(index_handle)

返回与缺少索引(不包括空间索引)的数据库表列有关的信息,sys.dm_db_missing_index_columns 是一个动态管理函数

字段解释

index_handle:唯一地标识缺失索引的整数。

sys.dm_db_missing_index_groups

返回有关特定缺失索引组中包含的缺失索引(不包括空间索引)的信息

sys.dm_db_missing_index_group_stats

返回缺失索引组的摘要信息,不包括空间索引

这个视图说白了就是预估有这麽一个索引,他的性能能提高多少

有一个字段比较重要:

avg_user_impact: 实现此缺失索引组后,用户查询可能获得的平均百分比收益。该值表示如果实现此缺失索引组,则查询成本将按此百分比平均下降。

就是说,增加了这个缺失索引,性能可以提高的百分比

下面是MSDN给出的示例,缺失索引组句柄为 2

示例代码:

我估计XX大侠做的SQLSERVER索引优化器也使用了"sys.dm_db_missing_index_details" 这个DMV

刚才看了一下,好像有错别字:Total Cost不是Totol Cost

暂时不知道Total Cost跟Improvement Measure怎麽算出来的

注意:

最后大家还需要注意一下,虽然这些DMV给出的建议还是比较合理的。

但是,DBA还是需要去确认一下建议。因为这个建议完全是根据语句本身给出的,

没有考虑对其他语句的影响,也没有考虑维护索引的成本,所以是很片面的。

其准确性,也要再确认一下

上面几个DMV的字段解释,大家可以看一下MSDN,非常详细

sys.dm_db_missing_index_group_statsmsdn:

推荐整理分享SQLSERVER如何查看索引缺失及DMV使用介绍(sqlserver如何查看操作日志),希望有所帮助,仅作参考,欢迎阅读内容。

SQLSERVER如何查看索引缺失及DMV使用介绍(sqlserver如何查看操作日志)

文章相关热门搜索词:sqlserver如何查看视图,sqlserver如何查看用户操作的记录,sqlserver如何查看版本,sqlserver如何查看用户操作的记录,sqlserver如何查看用户操作的记录,sqlserver如何查看操作日志,sqlserver如何查看版本,sqlserver如何查看操作日志,内容如对您有帮助,希望把文章链接给更多的朋友!

SQLSERVER记录登录用户的登录时间(自写脚本) 前一阵子经理问我能不能把用户最后一次登录我们的业务数据库的时间记录下来,因为之前有人修改过数据库sa用户的登录密码,所以我们要记录一下

SQLSERVER对索引的利用及非SARG运算符认识 写SQL语句的时候很多时候会用到filter筛选掉一些记录,SQL对筛选条件简称:SARG(searchargument/SARG)whereamountandamount上面这句就是筛选条件当然这里

将备份的SQLServer数据库转换为SQLite数据库操作方法 操作方法:先要安装好SQLServer,并且记住安装时自己设置的用户名和密码。下面以恢复SQLServer下备份的数据库文件epdmdb.bak为SQLite数据库为例来

标签: sqlserver如何查看操作日志

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

上一篇:诊断SQLSERVER问题常用的日志概述及使用(sql server常见故障)

下一篇:SQLSERVER记录登录用户的登录时间(自写脚本)(sqlserver登录日志)

  • 带息负债融资成本率意义
  • 购买免税产品的app
  • 纳税人识别号是什么哪里可以查到
  • 劳务外包人员算不算从业人员
  • 购进灭火器材怎么入账
  • 简易计税的进项可以抵扣吗
  • 增值税进项税转出政策依据
  • 企业人员信息已存在无需新增
  • 支付给个人的佣金怎么做账务处理
  • 退所得税的分录
  • 自建生产用机器设备领用本企业生产的产品
  • 印花税不计提是当月交当月吗
  • 工程技术服务费和技术服务费
  • 公司增值税发票有限额吗
  • 应征增值税不含税销售额(3%征收率)怎么算
  • 关于增值税报税的通知
  • 房地产行业应收帐款周转率平均值
  • 收派服务发票需交税吗
  • 发票升额需要什么条件
  • 财政总预算会计分为三级
  • 个税申报工资比实际工资高,汇算清缴时能退吗
  • 三证合一之后的税务登记
  • 一般纳税人普通发票跨月冲红流程
  • 农村合作社补贴政策
  • window10自带哪些软件
  • 贴息贷款利息怎么入账
  • php面向对象的三大特征
  • 微软正在更新office
  • 税收滞纳金可以抵税吗
  • 股权投资借差
  • 借支单怎么写才受法律保护
  • 大家在抢红包怎么回复
  • 国有企业所得税政策
  • 解决本地浏览器的方法
  • php __destruct
  • cuda运行环境
  • 07. vue3+vite+qiankun搭建微应用前端框架,并接入vue3微应用
  • 印花税城建税和教育费附加怎么算
  • 季报弥补亏损,财报怎么填
  • 监控设备属于固定资产还是在建工程
  • 如何隐藏应用软件华为
  • 织梦怎么采集文章
  • 医疗机构收据
  • 税控盘技术服务费抵扣期限
  • 分组计数什么意思
  • 母公司和子公司是什么关系
  • 非营利性养老院收费标准一般是多少
  • 年度纳税申报时间
  • 未取得发票如何报销
  • 长期投资损失
  • 待转销项税借方余额是什么意思
  • 土地流转的基本原则包括哪些
  • 营业外收入的账户结构
  • 金税盘技术维护费可以不交吗
  • 年度投资额看哪个科目
  • 小规模公司开票税率是多少
  • 如何把凭证装订机弄坏
  • mysql的innodb和myisam
  • select语句中的select*说明
  • mysql5.7.19 zip 详细安装过程和配置
  • Linux平台mysql开启远程登录
  • win8的文件夹选项在哪里
  • 免激活合法使用的软件
  • 平板电脑中的电池工作时是将什么能转化成了电能
  • 同一个局域网中,可以有两台dhcp服务器吗?为什么?
  • 晨枫U盘启动工具v2.0
  • u盘装win8系统教程图解
  • win8.1屏幕键盘
  • win10系统下如何安装谷歌浏览器插件?win10系统下谷歌浏览器插件的安装方法图文教程
  • nclaunch.exe - nclaunch进程有什么用 是什么意思
  • PQIBrowser.exe是什么进程 PQIBrowser进程查询
  • w8系统ie浏览器在哪
  • unity数学函数
  • three. js
  • 如何使用css进行网页布局,举例说明
  • java回收机制原理
  • nodejs基础
  • jQuery插件库
  • jQuery之简单的表单验证实例
  • 收到红字信息表不能直接开具
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设