位置: 编程技术 - 正文

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

  • 土地使用税怎么征收标准
  • 用房租入股
  • 如何存银行
  • 金融企业往来收入科目属于什么科
  • 受托代销商品和受托代销商品款是什么科目
  • 会计凭证保管的含义及要求
  • 以土地出资土地增值税
  • 支付以前年度的费用会计处理
  • 外出经营预缴税
  • 销项负数发票用勾选吗
  • 融资租赁的服务费的标准
  • 出口发票金额和备注了差了1分钱
  • etc开了充值发票还可以开消费发票么?
  • 发放年终奖计提需要调减利润吗
  • 物业公司收小区物业费吗
  • 红字发票信息表填好后再怎么操作
  • 为什么有些单位一直在招聘
  • 装修发票是什么发票
  • 2016年的发票可以用到什么时候
  • 更正申报增值税会产生滞纳金吗
  • 电子税务局实名采集怎么弄
  • 融资租赁与经营租赁的相同点
  • 补交的城建税怎么账务处理
  • 材料成本差异率要算发出材料吗
  • 资产负债一并转让增值税
  • 城镇地域
  • 生产车间领用材料45000元,投入生产
  • 建账时的库存怎么做账
  • 其他债权投资发生减值会影响所有者权益总额吗
  • PHP:curl_unescape()的用法_cURL函数
  • PHP:base64_encode()的用法_url函数
  • 特许权使用费属于销售收入吗
  • 白条入账会计要负刑事责任吗
  • thinkphp d
  • php数组操作函数
  • 上市公司回购股票意味着什么
  • php提供的字符串函数
  • 周末闲暇时光是什么意思
  • $ajax请求
  • cp命令复制文件到另一个目录并改名
  • php initialize
  • 个体工商户开税户
  • mysql备份导入
  • 海关缴款书上完税价格含增值税吗
  • 资产负债表怎么看盈利或亏损
  • 年均复合增长率该怎么算?
  • sql中判断函数
  • mac下安装mysql
  • 企业给灾区捐款可以抵税吗
  • 商铺固定设施指哪些
  • 个人开具发票需要税号吗?
  • 成本费用会计科目
  • mysql导入sql脚本指定编码
  • sql切割字段
  • iis6设置
  • xbox预览系统
  • 在linux操作系统中,/etc/rc.d/init.d
  • ubuntu14.04启动不了
  • Windows Server 8 ADDS轻松几步搞定密码个性化设置
  • windows8.1激活方法
  • win8更新80072efe
  • linux挂载啥意思
  • drawcalls2000多
  • javascript数据结构与算法项目计算找零
  • Bootstrap与KnockoutJs相结合实现分页效果实例详解
  • jQuery实现select模糊查询(反射机制)
  • 批处理语言 从入门到精通
  • perl使用保留字引用什么模块
  • angular页面加载完后执行方法
  • recycleview使用
  • shell删除指定内容
  • Embedded statement cannot be a declaration or labeled statement
  • jquery轮播代码
  • python爬虫利器
  • jQuery模拟select实现下拉菜单功能
  • android实战项目实例
  • 税务局航天信息的操作流程
  • 进项发票勾选认证如何导出明细
  • 税务注销了怎么查看纳税申报表
  • 原始股卖出多少需要披露
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设