Mysql SQL优化方法-阿里云开发者社区

开发者社区> 优惠券活动> 正文

Mysql SQL优化方法

简介: Mysql SQL优化方法 1.单库表别太多,一般保持在200以下为宜. 2.尽量避免SQL中出现运算,例如select a+5 from A,让DB功能单一化 3.表设计尽量小而精,能用5个字段就不要用6个(除非业务上使用增加冗余字段来提升性能)。
+关注继续查看

Mysql SQL优化方法

1.单库表别太多,一般保持在200以下为宜.

2.尽量避免SQL中出现运算,例如select a+5 from A,让DB功能单一化

3.表设计尽量小而精,能用5个字段就不要用6个(除非业务上使用增加冗余字段来提升性能)。

4.SQL事务不能设计太大,比如一次性提交10W条insert,当然这个不仅仅是性能问题了,可能直接内存溢出了。

一般来说insert事务的话,5K-1W来做批处理就可以了(字段不能太大)

5.设计表的时候尽量用”小数据类型”,比如尽量避免textblob等这些大家伙,优先使用ENUM和SET(小而美,范围有限,百益无一害)

6.设计表字段能用数字类型就千万别用字符类型,比如存IP地址,用int,别用varchar(方法自己百度一下吧)。

7.尽量避免null字段,定义时尽量使用 not null。原因是允许null时不方便查询优化,复合索引也会失效,而且如果列有索引时会额外占用空间: a int(10) NOT NULL DEFAULT 0

8.图片等大家伙不要存DB,用FastDFS等中间件或者直接使用七牛等云存储。

9.大SQL尽量拆分,多核CPU每个CPU只能执行一个SQL,所以并发时,一堆小的可能效率更高一些,并且容易命中缓存,而且不容易长时间锁表(无论什么锁都是时间越短越好),当然这个要结合实际情况分析了,一大堆小的万一增加IO负担呢。

10.事务尽可能的小,代码别偷懒,全加到一个transaction中,尽量使用多个transaction

11.存储过程,触发器之类的能避就全避免了吧,维护不方便,人员变动时,很多时候就忘了,时间一长全是定时炸弹。

12.禁止select *需要啥就取啥。

13.update时,where语句尽量要走索引,不然会全表扫描,一般情况下,1G的数据至少10S(想想这可是update啊,锁住10S意味着啥)。

14.or尽量不用,改为in(),当然in的范围太多也不行,尽量别超100。

15.还是or,如果:select a from A where b=1 or c=1这种where里面不同字段进行or,这种尽量改为union

select a from A where b=1
union
select a from A where c=1
  • 1
  • 2
  • 3

16.避免 “% 前缀”模糊查询 。因为会导致索引失效,大数据量下是灾难。

17.分页时:Select a from A limit 10000,10;这种大偏移量下效率非常低。可以考虑如下几个方案:

select a from A WHERE id>=xxxx limit 11;
(将上一页的最大值通过where id> 进行预处理,然后分页)
  • 1
  • 2
select a from A WHERE id >= ( select a from A limit 10000,1 ) limit 10;
  • 1
select a from A inner join (select a from A limit 10000,10) using (id) ;
  • 1

18.避免使用count(*),不知道为什么mysql优化这么个东西有那么难么,但是实际上大数量下这个东西真心慢,1000W以上至少几秒,作为替代方案,考虑使用nosql例如redismemcached存下来,但是要定时校对。

还有一个办法,直接做一个表存下来,每次增加或者减少都在这个表做update增减。

19.UNION ALL而非 UNION ,看需要啦,一般不用去重的业务的话去重压力不小,能省则省。

20.尽量不用 INSERT SELECT,数据量大有延迟,同步完了可能有错误。

原文地址 https://blog.csdn.net/jeikerxiao/article/details/81744271

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SQL优化二(SQL性能调优)
一·、前言:这篇博文内容非原创,是我们公司的架构师给我们做技术培训的时候讲的内容,我稍微整理了下,借花献佛。这篇博文只是做一个大概的科普介绍,毕竟SQL优化的知识太大了,几乎可以用一本书来介绍。另外,博主对SQL优化也是刚刚接触,也有很多不了解的地方,说的不对的地方,还请大家指正,共勉!   二、oracle服务器,所谓oracle服务器指的是一个数据库管理系统,它包括一个oracle实例(动态)和一个oracle数据库(静态)。
1202 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9980 0
SQL优化三步曲
三步改变线上业务库中SQL执行很满,导致每次跑1分钟才结束的难题。
249 0
关于sql优化(一)
关于sql优化(一) 在开发应用过程中,对数据的处理是比较重视的过程,因此对于优化sql或者是写出更加高效并且合适的sql尤为重要,下面我将描述sql优化的方法。     当一个sql性能有问题时,我们怎么样快速定位出该sql暴露出来的问题呢?     第一、通过show status命令了解sql的执行频率。
1084 0
MySQL慢SQL优化
基础知识 慢SQL官方定义 If a query takes longer than this many seconds, the server increments the Slow_queries status variable. If the slow query log is enabled, the query is logged to the slow query log file; Unit:Second. 阿里云控制台慢SQL参数 SQL优化原因与影响 •SQL优化原因:查询效率低的SQL(慢SQL)会占用机器大量的CPU、内存和IO资源,影响正常业务。
5334 0
MySQL进阶SQL优化
MySQL进阶SQL优化 查询效率分析: 子查询为确保消除重复值,必须为外部查询的每个结果都处理嵌套查询。在这种情况下可以考虑用联接查询来取代。 如果要用子查询,那就用EXISTS替代IN、用NOT EXISTS替代NOT IN。
2634 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
10879 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13751 0
SQL优化之使用正确的去重方法
DISTINCT到底该不该使用
962 0
+关注
优惠券活动
阿里云优惠码阿里云推荐券bieryun.com
389
文章
9
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载