位置: 编程技术 - 正文

详解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作用详解

  • 息税前利润和销售利润
  • 不动产租赁税率2023
  • 将自产货物赠送客户
  • 以前年度损益调整科目怎么用
  • 暂估入库发票回收怎么办
  • 经营许可证要交税吗
  • 单位注册表从哪里获取
  • 企业政策性搬迁损失的所得税处理
  • 经常性支出是什么意思
  • 并购重组资产怎么算
  • 贷款利息进项税额
  • 主营业务收入借方负数表示
  • 开保函会计分录
  • 延期付款利息是多少钱
  • 上年度的印花税怎么计算
  • 企业所得税减免税额包括哪些
  • 生产用水的会计分录
  • 小规模纳税人税收优惠政策
  • 现金采购合理吗
  • 预缴和实际应付的区别
  • 作废已开具的普通发票
  • 包装物押金如何确定销售额?
  • 资本弱化管理规定最新
  • 电脑删文件需要授权
  • 电脑蓝屏代码0x0000003B
  • 非上市公司转让股权需要缴纳增值税吗
  • 退税需要怎么操作
  • iphone和电脑同步
  • 航天税控服务费
  • Win10 KB5004945 更新后多个品牌打印机无法使用的解决方法
  • php和数据库
  • PHP:mb_detect_order()的用法_mbstring函数
  • 企业补充养老保险
  • 营改增后企业一般纳税人认定标准为
  • js设置input值
  • 前端常问的面试题
  • php年月日时间代码
  • transformer add norm
  • php设计模式六大原则
  • 商业汇票如何申请操作
  • 无偿调入固定资产怎么入账
  • 电子发票怎么开具流程呢?
  • 法人向公司账户打款
  • 一年内到期的非流动资产
  • 专用红字发票如何开具
  • sqlserver经典书籍
  • 视同销售收入是纳税调整项目吗?
  • 设备维修会计分录如何写
  • 汇算清缴 房租
  • 分期付款服务费是什么
  • 动迁补偿金
  • 取得下列资产时应按公允价值计量
  • 其他公司借款现金怎么办
  • 困难补助属于兜底政策吗
  • 专票先不认证如何申报增值税
  • 参加会议正常应该交多少钱
  • 销项负数发票如何作废
  • MySQL关键字执行顺序
  • windows在哪里添加打印机
  • win7提示盗版怎样激活
  • win7系统隐藏文件夹怎么取消隐藏
  • win7打开游戏显示已停止工作
  • linux投屏快捷键
  • linux查看mtime的命令
  • win7无法远程桌面win10
  • win7网上邻居怎么共享文件数据
  • win8更新错误
  • 如何在手机上直接买彩票
  • bootstrap表单模板
  • Node.js中的construct
  • three.js入门教程(合集)
  • 浅谈 javascript 事件处理
  • jquery选择器的分类有哪些
  • python中创建自定义函数
  • 如何查询税务情况
  • 税务投诉回访电话号码
  • 医保报销是按自然年计算吗
  • 落地和全包一样吗
  • 四川省成都市地图高清版大图
  • 福建地税网上办事大厅
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设