热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Mysql性能优化札记_mysql

一,索引1.Innodb索引使用的是B+树2.尽量简化where条件,比如不要出现whereid+

mysql性能优化笔记

一,索引

1.Innodb索引使用的是B+树

2.尽量简化where条件,比如不要出现 where id + 3 = 5,这无法使用索引

3.索引很大时,可以冗余一列来模拟哈希索引

4.小的表不需要使用索引,很大的表需要用分块技术,也不用索引

5.索引的选择性=不重复的数量/总的数量

选择性越高,效率越高,unique索引选择性为1,效率最好

对于blob,text,很长的varchar类型的列,必须使用前缀索引。

诀窍在于,要选择足够长的前缀以保证较高的选择性,同时又不能太长

创建前缀索引:(city列里长度为7的前缀索引)

alter table sakila.city_demo ADD KEY(city(7))

前缀索引的缺点,无法做ORDER BY和GROUP BY

后缀索引:mysql不支持反向索引,但可以把字符串反转后存储,并基于此建立索引,可以通过触发器来维护索引

6、多列索引

对多个列做相交操作(and)时,需要的时一个多列索引而不是多个单独的单列索引

如果在explain中看到有索引合并,应该好好检查一下查询和表单结构,

可以通过参数optimizer_switch来关闭索引合并

7.覆盖索引

如果一个索引包含所有需要查询的字段的值,我们就称之为覆盖索引

由于myISAM在内存中只存索引,所以用覆盖索引有严重的性能问题

由于InnoDB的聚簇索引,覆盖索引对InnoDB特别有用

另外,只能用B-tree索引做全文索引

当使用覆盖索引时,EXPLAIN 中的Extra中显示Using index

查询优化

一般的优化方法有两个

1.确认应用程序是否在检索大量超过需要的数据,这通常意味着访问了太多的行

但有时候也可能是访问了太多的列

2.确认MySQL服务器层是否在分析大量超过需要的数据行

解决方法,加limit,

如果数据库资源紧张,可以考虑用mybatis代替hibernate

取出全部列,会让优化器无法完成覆盖索引扫描这类优化,比如hibernate

不过获取所有列的查询缓存,比多个独立的只获取部分列的查询缓存更有好处

每次看到select * 请去怀疑一下是否真的需要全部取出 

重复查询相同的数据:请把这个数据缓存起来,比如放到session中

最简单的衡量查询开销的三个指标:

响应时间,

扫描的行数

返回的行数

这三个指标都会记录到mysql的慢日志中,所以检查慢日志

如果发现查询需要扫描大量的数据行,但返回少量的行,那么可以尝试下面的技巧去优化它

1,使用索引覆盖扫描,把所有需要用的列都放到索引中

2.改变表结构,例如使用单独的汇总表

3.重写这个查询,各种优化

有时可以考虑将一个复杂查询分为多个小查询,如果能减少工作量的话

比如删除旧的数据,每次删一点,可以避免一次锁住很多数据

分解关联查询的好处

1、缓存效率更高

2、用返回的数据的id来进行顺序查询比用join进行随机关联效率更高

坏处:一条语句分多条,增加连接开销

Mysql性能优化札记_mysql

 排序优化

无论如何,排序都是一个成本很高的操作,所以从性能角度考虑,尽可能避免排序,或避免对大量数据进行排序

欢迎大家阅读《Mysql性能优化札记_mysql》,跪求各位点评,by



推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了在处理不规则数据时如何使用Python自动提取文本中的时间日期,包括使用dateutil.parser模块统一日期字符串格式和使用datefinder模块提取日期。同时,还介绍了一段使用正则表达式的代码,可以支持中文日期和一些特殊的时间识别,例如'2012年12月12日'、'3小时前'、'在2012/12/13哈哈'等。 ... [详细]
  • 本文介绍了Redis中RDB文件和AOF文件的保存和还原机制。RDB文件用于保存和还原Redis服务器所有数据库中的键值对数据,SAVE命令和BGSAVE命令分别用于阻塞服务器和由子进程执行保存操作。同时执行SAVE命令和BGSAVE命令,以及同时执行两个BGSAVE命令都会产生竞争条件。服务器会保存所有用save选项设置的保存条件,当满足任意一个保存条件时,服务器会自动执行BGSAVE命令。此外,还介绍了RDB文件和AOF文件在操作方面的冲突以及同时执行大量磁盘写入操作的不良影响。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • Android自定义控件绘图篇之Paint函数大汇总
    本文介绍了Android自定义控件绘图篇中的Paint函数大汇总,包括重置画笔、设置颜色、设置透明度、设置样式、设置宽度、设置抗锯齿等功能。通过学习这些函数,可以更好地掌握Paint的用法。 ... [详细]
author-avatar
无内功不5功
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有