位置: 编程技术 - 正文

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

发布时间:2024-02-26

推荐整理分享详解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申请一般纳税人公司的条件
  • 网络技术服务费 税率
  • 招聘签合同
  • 车辆进项税怎么算
  • 保安服务费可以开具专票吗
  • 差额征税可以享受1%
  • 承兑汇票背书用什么方法?
  • 企业收入代扣税金应该怎么做会计处理?
  • 主营业务收入写不写明细
  • 买购物卡发福利怎么发
  • 预付卡发给员工如何入账
  • macos big sur如何
  • 无法收回的应收票据怎么处理
  • 清除cmos有什么后果
  • window10系统有几种
  • wordpress主题dux
  • phpwind教程
  • php的pdo
  • 母公司向子公司发行面值100万元、期限为三年
  • php数组函数 菜鸟
  • 出口免抵增值税是什么意思
  • php curl cookie
  • 写字楼租赁房产税
  • 做毕业设计,前景如何
  • 阿里pv
  • 功能强大的php发展趋势
  • 应收账款期末余额在借方还是贷方
  • 没有取得发票就把车卖了违法吗
  • python insert方法
  • 公司业务订金怎么退
  • 小型生产加工企业税率
  • 修理费账务处理
  • 小规模出售固定资产账务处理
  • 其他应收款借方表示增加吗
  • 利润表和资产负债表不平的原因
  • 开银行承兑汇票需要多少保证金
  • 政府补助的分类及会计处理方法有哪些
  • 营业成本利润率行业均值
  • 入账价值有
  • 生产过程中产品质量问题
  • 除了增值税专用发票,还有什么发票可抵扣
  • 个体工商户必须建账吗
  • 金税盘销项税额怎么导出来
  • 企业应该设置的账薄
  • 怎样才能制作出白瓷
  • 如何考预算师
  • 会计存货包括生产成本
  • 总分类账建账顺序
  • win10如何设置视频缩略图
  • 还原精灵使用教程
  • 阿里云电脑系统
  • win8.1快捷键
  • find按照文件大小查找
  • 应该怎么修复
  • linux 压缩rar
  • jquery.multiselect多选下拉框实现代码
  • jQuery autoComplete插件两种使用方式及动态改变参数值的方法详解
  • jquery点击跳转页面
  • 说一说我下乡插队时的那点事
  • js写后端用什么框架
  • js按下回车键时提交
  • 甘肃国家税务总局
  • 苏州公积金密码怎么改
  • 专票最高几个点
  • 税务负责人
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号