mysql查询优化:
1.新增字段索引,查询时若使用到or关键字,则两个字段都需建立索引才能生效
2.sql语句包含子查询,mysql会创建临时表查询结束后删除,影响效率,所以应尽可能使用join替代子查询
3.将字段多的表分解成多表:将表中使用频率较低的字段单独存入到其他的表中
4.添加中间表:经常联合查询的表,将需要通过联合查询的数据插入到中间表中,然后将原来的联合查询改为对中间表的查询。
5.适当添加冗余字段
mysql插入优化:
1.禁用唯一性检查: set unique_checks = 0; //0:禁用,1:启用
2.禁用外键检查:set foreign_key_checks = 0;//0:禁用,1:启用
3.禁用自动提交: set autocommit = 0 ; //0:禁用,1:启用
注意:不同的数据库引擎优化手段不一样,在Mysql中常用的存储引擎:MyISAM和InnoDB
MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。如果应用中需要执行大量的SELECT查询,那么MyISAM是更好的选择。
InnoDB用于事务处理应用程序,具有众多特性,包括ACID事务支持。如果应用中需要执行大量的INSERT或UPDATE操作,则应该使用InnoDB,这样可以提高多用户并发操作的性能。
数据库服务器优化(硬件):
1、配置较大的内存。足够大的内存,是提高MySQL数据库性能的方法之一。内存的IO比硬盘快的多,可以增加系统的缓冲区容量,使数据在内存停留的时间更长,以减少磁盘的IO。
2、配置高速磁盘,比如SSD。
3、合理分配磁盘IO,把磁盘IO分散到多个设备上,以减少资源的竞争,提高并行操作能力。
4、配置多核处理器,MySQL是多线程的数据库,多处理器可以提高同时执行多个线程的能力。