精简语句吧,让你的MySQL更有效

原创
数据库 MySQL 数据库运维
如何可以快速提高MySQL服务器的扩张性?我们可以通过几条简单的规则,方便地提高MySQL服务器的扩展性。

【51CTO独家译文】简易教学之快速提高扩展性

通过几条简单的规则,我们可以方便地提高MySQL服务器的扩展性。以下是实例之一。

 “改进SQL语句最有效的方法是进行精简

[[20928]] 

精简SQL语句的方法林林总总,但在列举由客户处观察得出的典型范例之前,请允许我先对提高扩展性的基本前提条件做出解释。

MySQL的核心只允许在给定的时间段(例如每秒)中借由物理过程来运行一定数量的SQL语句。无论你的计算机有多么强力,这一物理过程始终存在运算上限。如果你能够将SQL语句中那些不具备关键性或必要性的部分精简掉,那么与此同时,真正重要的SQL语句也将自动得到优先处理。当然这也将带来其它一些连锁反应,但只是简单数学范畴内的小问题。总之,要运行更多SQL指令,首先对你的指令进行精简

在此我们列举一个简单的例子,通过mk-query-digest工具对TCP/IP数据包进行分析并输出结果。

  1. # Rank Query ID           Response time Calls R/Call Apdx V/M   Item  
  2. # ==== ================== ============= ===== ====== ==== ===== ==========  
  3. #    1 0xD631CB919867DB50  0.0436 47.3%    92 0.0005 1.00  0.00 SELECT TTDOD  
  4. #    2 0x04FE01C5B31FD305  0.0258 27.9%   329 0.0001 1.00  0.00 ADMIN PING  
  5. #    3 0x93321857BCD8E771  0.0229 24.8%    36 0.0006 1.00  0.00 SELECT TTD 

 其中存在很多问题,包括SQL的一次一行(RAT)特性,不过在这里我们暂不讨论ping过多的问题。首先让我们看看***个语句。

  1. SELECT `DateFROM TTDOD WHERE ID = 9999; 

表面上看这个查询指令已经够简洁了,但让我们再看看列表。

  1. mysql> select count(*) from TTDOD;  
  2. +----------+  
  3. count(*) |  
  4. +----------+  
  5. |        0 |  
  6. +----------+ 

在这种情况下,因为当前列表是空的,所以查询指令将不会返回任何内容。当然这一点在未来可能会发生变化,但就目前来看这更多的是一种在简单数据管理中的异常处理状态,因为该列表中很少会存在内容。而建立一种有针对性的解决方案来通知该应用程序,可以完全避免这类不必要的查询行为。

以上只是个运行时间不足2秒的参考实例,而清除***个查询指令也已经使整体查询时耗降低了20%。不管这仅仅是个典型的载入过程抑或是批处理中的并行载入过程,原理都是共通的。而且毫无疑问,在接下来的查询指令中,我们的精简工作还大有可为。

原文地址:http://ronaldbradford.com/blog/simple-lessons-in-improving-scalability-2011-02-16/

【编辑推荐】

  1. 十个节省时间的MySQL命令
  2. MySQL数据库分区管理 细节决定成败
  3. 降低锁竞争 减少MySQL用户等待时间
  4. 浅析MySQL数据碎片的产生
  5. 如何解决IBatis.net与MySQL连接问题                                                                
责任编辑:艾婧 来源: 51CTO
相关推荐

2016-03-28 10:11:37

2021-07-12 14:50:25

Linux命令文件

2022-05-07 09:32:01

Ubuntu编程Linux

2020-12-09 22:00:38

GitLinux版本控制系统

2015-08-19 13:40:58

编程编程更有效

2021-06-03 23:03:42

区块链薪资技术

2021-03-16 05:42:39

开源工具技术干货

2021-07-30 16:42:53

开源工具开发

2017-06-19 08:59:06

2013-04-01 00:43:50

华为金华威

2013-04-01 00:59:33

金华威华为

2018-07-23 13:02:30

数据可视化颜色数据

2013-10-16 09:51:21

时间管理效率管理

2010-11-24 13:31:20

MYSQL表联结

2009-11-23 20:36:35

ibmdwRational

2020-08-18 07:52:06

GitHub程序开源

2012-10-24 09:42:27

数据安全BYOD云数据

2012-05-02 10:03:56

2016-04-28 16:17:44

又拍云/CDN

2009-05-26 14:56:43

Linux系统硬盘优化
点赞
收藏

51CTO技术栈公众号