本文作者:kris

几个常见的MySQL的可优化点归纳总结-mysql有哪些优化

kris 2025-01-27 13:24:04 3
几个常见的MySQL的可优化点归纳总结-mysql有哪些优化摘要: mysql 性能优化推荐书籍?1.《高性能MySQL》noDB存储引擎》noDBnoDB的架构、索引、事务、锁等方面的知识,并且给出了大量的实例和性能测试结果,非常适合MySQL的...

mysql 性能优化推荐书籍?

1.《高性能MySQL》

noDB存储引擎》

noDBnoDB的架构、索引、事务、锁等方面的知识,并且给出了大量的实例和性能测试结果,非常适合MySQL的进阶者。

3.《MySQL性能调优与架构设计》

4.《MySQL技术内幕:SQL优化》

mysql频繁写入有什么优化方法没?

1.优化数据结构,每张数据表字段4-5个,加上索引。还可以将不同的种类的数据存入不同的数据库。减少单个数据库的压力。

2.写入数据只是存的问题,问题在于读取数据会变慢。建议使用缓存memcache,redis在向你招收哦。将用户数据存入内存,再次读取避免从数据库查找。

3.分布式,搞集群,扩大配置。

一条新闻的相关信息,来源,作者,正文,这些基本不变咯,除了正文可能文字比较多,其他的你可以存进缓存,正文的话,你这里可以把前面200字作为正文缩略,存进缓存。

mysql语句中in的字段过多怎么优化?

当使用多个字段进行IN子查询时,可以考虑将这些字段的值放入临时表中,并通过JOIN来优化查询性能。

首先创建临时表,然后将需要过滤的值插入临时表中,最后通过JOIN把临时表和原表连接起来进行查询。这样可以避免过多字段在IN子查询中造成性能下降的问题。同时,也可以考虑对需要过滤的字段进行索引优化,提高查询效率。

mysql优化教程?

1、对SQL语句、索引、表结构等进行优化。

2、开启查询缓存,Query Cache缓存了SELECT查询及其结果数据集,当执行一个同样的SELECT查询时,MySQL会从内存中直接取出结果,加快了查询执行速度、减小了数据库的压力。执行SHOW VARIABLES LIKE 'have_query_cache';可以查看MySQL查询缓存是否打开,开启查询缓存只需配置my.cnf文件即可,具体如下:

query_cache_type = 1

query_cache_size = 128M

query_cache_limit = 1M

几个常见的MySQL的可优化点归纳总结-mysql有哪些优化

图片来源:网络

保存好后重启MySQL。

3、选用InnoDB存储引擎,MySQL常用存储引擎是MyISAM和InnoDB,二者区别如下:

MyISAM

查询速度快;

支持表级锁,在上锁期间表上不能进行其他操作;

支持全文检索;

支持数据压缩、自我复制、查询缓存、数据加密;

不支持外键;

不支持事务,所以也就没有COMMIT和ROLLBACK操作;

不支持集群数据库。

InnoDB

支持行级锁;

支持外键,对外键约束强制;

支持事务,可执行COMMIT和ROLLBACK操作;

支持数据压缩、自我复制、查询缓存、数据加密;

可用在集群环境,但并不完全支持。InnoDB表可以转换为NDB存储引擎,这样就能用在集群环境。

MySQL的优化要根据实际业务,并没有什么通用的优化。

其实其他回答都说的很全,

但是我从比较实际的地方说说吧。

第一、开启MySQL的slowLog

slowLog会记录MySQL执行过的慢查询,比较佛系的办法就是让它记录一段时间,

然后查看里面执行的语句。

第二、通过desc的方式来查看慢的原因

比如:SELECT * FROM tbl WHERE Date = CURDATE();

你可以通过执行 desc SELECT * FROM tbl WHERE Date = CURDATE();

这个时候Mysql就会显示执行这句sql的计划,

如果你发现是全表查询,这个时候尝试在Date上增加索引,

然后再跑一次DESC,这个时候你就会发现这句语句已经走了索引。

*通常这个办法能解决90%的慢查询问题。

当上面的问题都无法满足到你的时候,

建议可以参考Mysql官方的参数设定,

然后根据业务特性对MySQL进行特定优化。

文章版权及转载声明

作者:kris本文地址:https://www.damoyx.com/p/27925.html发布于 2025-01-27 13:24:04
文章转载或复制请以超链接形式并注明出处大漠游侠网

阅读
分享