位置: 编程技术 - 正文

详解mysql中的冗余和重复索引(mysql冗余字段)

编辑:rootadmin

推荐整理分享详解mysql中的冗余和重复索引(mysql冗余字段),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:数据库中的冗余度是什么意思,mysql删除冗余数据,mysql删除冗余数据,数据库中的冗余度,mysql 冗余,数据库中冗余的概念,mysql数据冗余,mysql数据冗余,内容如对您有帮助,希望把文章链接给更多的朋友!

mysql允许在相同列上创建多个索引,无论是有意还是无意,mysql需要单独维护重复的索引,并且优化器在优化查询的时候也需要逐个地进行考虑,这会影响性能。

  重复索引是指的在相同的列上按照相同的顺序创建的相同类型的索引,应该避免这样创建重复索引,发现以后也应该立即删除。但,在相同的列上创建不同类型的索引来满足不同的查询需求是可以的。

这段SQL创建了3个重复索引。通常并没有理由这么做。

  冗余索引和重复索引有一些不同,如果创建了索引(a,b),再创建索引(a)就是冗余索引,因为这只是前面一个索引的前缀索引,因此(a,b)也可以当作(a)来使用,但是(b,a)就不是冗余索引,索引(b)也不是,因为b不是索引(a,b)的最左前缀列,另外,其他不同类型的索引在相同列上创建(如哈希索引和全文索引)不会是B-Tree索引的冗余索引,而无论覆盖的索引列是什么。

  冗余索引通常发生再为表添加新索引的时候。例如,有人可能会增加一个新的索引(A,B)而不是扩展以后的索引(A)。还有一种情况是将一个索引扩展为(A,ID),其中ID是主键,对于InnoDB来说主键已经包含在二级索引中了,所以这也是冗余的。

  大多数情况下都不需要冗余索引,应该尽量扩展已有的索引而不是创建新索引,但也有时候处于性能方面的考虑需要冗余索引,因为扩展已有的索引会导致其变得太大,从而影响其他使用该索引的查询性能。如:如果在整数列上有一个索引,现在需要额外增加一个很长的varchar列来扩展该索引,那么性可能会急剧下降,特别是有查询把这个索引当作覆盖索引,或者这是myisam表并且有很多范围查询的时候(由于myisam的前缀压缩)

详解mysql中的冗余和重复索引(mysql冗余字段)

  比如,有一张userinfo表。这个表有条数据,对每个state_id值大概有条记录。在state_id有一个索引,那么下面的SQL我们称之为Q1

改查询的执行速度大概是每秒次(QPS)

  还有一个SQL,我们称之为Q2

这个查询的QPS是,提升该索引性能最简单的办法就是狂战索引为(state_id,city,address),让索引能覆盖查询:

注:state_id已经有索引了,根据前面的概念,这是一个冗余索引而不是重复索引)

怎么找出冗余索引和重复索引呢?

1.可以使用Shlomi Noach的common_schema中的一些试图来定位,common_schema是一系列可以安装到服务器上的常用的存储和试图。

2.可以使用Percona Toolkit中的pt_duplicate-key-checker,该工具通过分析表结构来找出冗余和重复的索引。

总结

标签: mysql冗余字段

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

上一篇:MySQL语句加锁的实现分析(mysql 加锁处理分析)

下一篇:Mysql中explain作用详解

  • 2021年9月个税申报截止时间
  • 利润表季度怎么填写
  • 成品出库单模板表格制作
  • 租的厂房水电费开不了发票怎么办
  • 劳务公司一般纳税人开票几个点
  • 代扣代缴车船税手续费比例
  • 发票中奖要交税吗
  • 增值税采用
  • 增值税专票怎么抵扣
  • 应收银行存款利息怎么算
  • 个体工商户生产经营所得税率
  • 本期已认证但不想抵扣申报表怎么填写
  • 幼儿园增值税优惠政策
  • 福利费实物发放标准
  • 三证合一之后还有税务登记证吗
  • 所得税相关分录
  • 劳务费差额征税的账务处理
  • 资本公积转增资本的条件
  • 通用机打发票上没有税率
  • 航道疏浚服务属于什么服务
  • 当月增加的固定资产
  • 其他收益科目核算
  • 零星工程实施流程
  • centos7安装部署cacti教程
  • wps的广告怎么关掉
  • 你知道怎么安装
  • 分公司特征表述正确的是
  • 苹果手机查找对方手机位置看不到
  • 现金流量套期的例子
  • 小规模企业有收入吗
  • 在建工程进项税额转出
  • framework3.5怎么打开
  • 逆回购利息计算公式
  • framework7教程
  • laravel phpstudy
  • 装修费还没摊销完就搬家了
  • 多线程的弊端
  • vue鼠标悬浮菜单
  • 增值税小规模纳税人
  • 往来款的意思
  • 酒店业营业税税率
  • Parcel 中文文档 | Parcel 中文网
  • 采购供应部门发挥的作用
  • 房地产开发间接费用和开发费用的区别
  • c语言http请求解析表单内容
  • 购进交通运输服务可以抵扣
  • 只有收入没有成本怎么做账
  • 持有至到期投资减值准备
  • 购买固定资产进项税现金流量
  • 发票红冲重开是退个税吗
  • 现金存入银行的会计凭证
  • 以前年度少计提的工资怎么处理
  • 电力安装工程合同税率能开13%
  • 财务费用中的汇兑损益和汇兑收益的区别
  • 预付卡发票如何做分录
  • 个人承担的社保算公司的费用吗
  • mysql中排序
  • 返回sql执行时间的方法
  • mac装双系统后无法开机
  • mac的dns怎么设置最快
  • 怎么恢复被破坏的文件
  • swstrtr.exe - swstrtr是什么进程
  • win8.1专业版是哪个
  • win7系统耳机设置在哪里
  • win7如何卸载打印机驱动程序
  • Win10 Mobile RedStone预览版14267.1004更新内容汇总(持续更新)
  • 字符串反转C语言代码
  • linux中shell的作用
  • 删除了c盘安全组或用户
  • python根据ip获取主机名
  • python中生成随机小数的函数
  • android天气预报课程设计报告
  • 湖南国家电子税务局手机版
  • 国企9000扣完五险一金
  • 车辆购置税怎样交
  • 小规模纳税人房土两税优惠政策
  • 个体户定额怎么查询
  • 建筑装饰业发票怎么开
  • 季度申报忘了报怎么办
  • 税务申报按季度申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设