位置: 编程技术 - 正文

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

  • 北京市增值税发票查验平台
  • 一般纳税人销售货物税率
  • 所得税资产和所得税费用
  • 营业外收入交企业所得税可以扣除成本么
  • 小企业会计利润报表
  • 中央空调折旧年限是多久
  • 营业外收入记账
  • 个人所得税该如何缴纳
  • 工程项目垃圾清运项目编码
  • 哪些房屋交易需要公证
  • 应交城市维护建设税分录怎么做
  • 增值税只有销项没有进项怎么做账
  • 如何能减免个人所得税
  • 7月财务报表行次三大变化
  • 价值多少可以确认收入
  • 手工帐财务费用怎么结转
  • 银行支票怎么用
  • a公司转给b公司投资款的会计分录
  • 房地产会计分录大全
  • 怎么分配工业企业材料费用?
  • 房屋租赁公司和公寓管理公司区别是什么
  • win10消费者版本和商业版本有什么区别
  • 系统设置自动还原
  • macos monterey支持哪些显卡
  • 非上市公司转让股权需要缴纳增值税吗
  • 存货成本要加上税费吗
  • 坏坏狼故事绘本
  • 如何找装修公司
  • 建筑行业挂靠开票怎么做账务处理?
  • 微信小程序解决跨域问题
  • 公司制作横幅计入什么科目?
  • 发现新大陆的是麦哲伦还是哥伦布
  • 为什么股本溢价
  • 所得税预缴申报表怎么填
  • 计提怎么理解
  • 租赁发票的租赁日期怎么写
  • 建筑公司包含哪些业务
  • 02-MyBatis-Plus
  • 个税租房租金扣除规则
  • 电子发票开出后如何查看
  • 小规模纳税企业销售货物或者提供应税劳务
  • 营改增后为什么利息要提供发票吗
  • 摘要概括增值税专用发票的基本联次
  • 股权转让个人所得税怎么算
  • 信用减值损失转回的会计处理
  • 印花税啥样
  • 本月未抵扣完的进项税是否转出
  • 委托生产的会计分录
  • 非居民企业所得税
  • 上年的应收帐款怎么记账
  • 融资租赁汽车怎么投诉电话
  • 退货只能退一半价钱合理吗
  • 预收账款结转收入分录
  • 计提本月工资的账务处理
  • 应计入营业外支出的有哪些
  • 期末损益类科目结转
  • 科目汇总表里的应交税费
  • 学会计前景好吗
  • 怎么打开设置管理
  • win8电脑无法识别usb设备怎么办
  • win8.1配置要求
  • wpr02
  • xp系统要求
  • linux中mail命令
  • linux修改ssh端口号启动失败
  • ubuntu 无法正常启动
  • os x 10.10.5
  • 笔记本w8系统怎么取消开机密码
  • win10系统自带虚拟机无法启
  • nodejs的应用场景和优缺点
  • unity rpg插件
  • linux定时备份文件
  • python关键字none
  • js中的substring
  • javascript中的数据类型分为两大类
  • acrag
  • 税务和海关哪个单位比较好
  • 广东省通用机打发票怎么开
  • 豫麦336
  • 贵州省国家税务局电子税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设