开发者社区> 余二五> 正文

精简SQL语句 提高MySQL服务器的扩展性

简介:
+关注继续查看

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

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

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

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

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

  以下是代码片段:

  # Rank Query ID Response time Calls R/Call Apdx V/M Item

  # ==== ================== ============= ===== ====== ==== ===== ==========

  # 1 0xD631CB919867DB50 0.0436 47.3% 92 0.0005 1.00 0.00 SELECT TTDOD

  # 2 0x04FE01C5B31FD305 0.0258 27.9% 329 0.0001 1.00 0.00 ADMIN PING

  # 3 0x93321857BCD8E771 0.0229 24.8% 36 0.0006 1.00 0.00 SELECT TTD
其中存在很多问题,包括SQL的一次一行(RAT)特性,不过在这里我们暂不讨论ping过多的问题。首先让我们看看第一个语句。

  以下是代码片段:

  SELECT `Date` FROM TTDOD WHERE ID = 9999;
表面上看这个查询指令已经够简洁了,但让我们再看看列表。

  以下是代码片段:

  mysql> select count(*) from TTDOD;

  +----------+

  | count(*) |

  +----------+

  | 0 |

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

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










本文转自 wws5201985 51CTO博客,原文链接:http://blog.51cto.com/wws5201985/764542,如需转载请自行联系原作者

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

相关文章
阿里云服务器怎么搭建sql server(即 MS SQL)?
本文从远程桌面连接,到SQL SERVER安装进行了系统介绍。购买前请先:领取阿里云幸运券,有很多优惠,下文中有领取链接。 购买建议多买几年,年数越多优惠越多。
9263 0
使用OpenApi弹性释放和设置云服务器ECS释放
云服务器ECS的一个重要特性就是按需创建资源。您可以在业务高峰期按需弹性的自定义规则进行资源创建,在完成业务计算的时候释放资源。本篇将提供几个Tips帮助您更加容易和自动化的完成云服务器的释放和弹性设置。
18714 0
WINDOWS XP系统安装SQL server服务器版
为了帮朋友解决在WINDOWS XP系统上无法安装SQL server服务器版的问题,只好也装了一套WINDOWS XP系统,参考网上以及其它资料,现已经成功的在WINDOWS XP系统安装了SQL server服务器版,希望对需要的网友会有一定的帮助,不多说,步骤如下:   一、找一张SQL server服务器版光盘,在光盘上找到目录“MSDE”并进入,运行SETUP.EXE文件,并按照程序要求进行安装。
951 0
SQL Server服务器最新漏洞解决方法
漏洞扩展:xp_dirtree储存过程      事前:最近发现一个漏洞是sql服务器造成的,前几天正好没有什么事情,就用阿d的sql注入工具对自己服务器的网站进行注入,偶然发现了使用mssql的网站浸染可以利用sql注入的形式得到整个服务器上所有目录(我的服务器作了安全设置的)依然可以...
814 0
+关注
20381
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载