更优更快
人工智能自动
SQL优化----------http://www.sina.com.cn 2001/12/12 17:48 中国电脑教育报文/
SQL爱好者 所谓
SQL,就是指Structured Query Language(结构化查询语言),它是目前使用最广泛的
数据库语言,用来和
数据库打交道,从
数据库中得到用户需要的数据。但是要想熟练使用
SQL语句,也不是一件简单的事,有些语句使用起来也比较麻烦。如果我们对
SQL语句进行
优化,那么用户使用起来 就会方便许多。 简单来说,
SQL语句的
优化就是将性能低下的
SQL语句转换成达到同样目的的性能优异的
SQL语句。
人工智能自动
SQL优化就是使用
人工智能技术,自动对
SQL语句进行重写,找到性能最好的等效
SQL语句。
人工智能自动
SQL 优化 随着
人工智能技术的发展和在
数据库优化领域应用的深入,在20世纪90年代末终于出现了突破性的进展——
人工智能自动
SQL优化。目前在商用
数据库领域LECCO TechnologyLimited(灵高公司)
拥有该技术并提供使用该技术的自动
优化产品——LECCO
SQL Expert,其支持Oracle、Syb
ase、MS
SQLServer和IBMDB2
数据库平台。该产品针对
数据库应用的开发和维护阶段提供了几个特别的模块:
SQL语法
优化器、PL/
SQL集成化开发调试环境(IDE)、扫描器、
数据库监视器等。图1
人工智能自动
SQL优化示意图 其核心模块之一“
SQL语法
优化器”的工作原理大致如下(如图1): 一条源
SQL语句输入→“
人工智能反馈式搜索引擎”对输入的
SQL语句结合检测到的
数据库结构和索引进行重写,产生N条等效的
SQL语句输出→产生的N条等效
SQL语句再送入“
人工智能反馈式搜索引擎”进行重写,直至无法产生新的输出或搜索限额满→对 输出的
SQL语句进行过滤,选出具有不同
执行计划的
SQL语句(即不同的
执行效率)→对得到的
SQL语句进行批量测试,找出性能最好的
SQL语句。图2
优化前的
SQL语句 自动
优化实例 假设我们从源代码中抽取出这条
SQL语句(如图2): SELEC
TCOUNT(*)FROMEMPLOY-EE WHER
EEXISTS(SELEC
T
'X
'FROM DEPARTMENTswher
esEMP_DEPT=DPT_IDAND DPT_NAME LIKE
'AC%
')AND EMP_IDIN(SELEC
T SAL_EMP_IDFROM EMP_SAL_HISTB WHER
ESAL_SALARY>70000) 按“
优化”按钮后,经过十几秒,
SQL Expert就完成了
优化的过程,从
优化细节中可以看到,它在十几秒的时间内重写产生了2267条等价的
SQL语句,其中136条
SQL语句有不同的
执行计划(如图3)。图3
优化结果 接下来我们可以对自动重写产生的136条具有不同
执行计划的
SQL语句进行批运行测试,以选出性能最佳的等效
SQL语句。按下“批运行”按钮,在“终止条件”页选择“最佳运行时间
SQL语句”(如图4),按“确定”。图4 测试条件 经过几
分钟的测试运行后,我们可以发现
SQL124的运行时间和反应时间最短。运行速度约有22.75倍的提升(源
SQL语句运行时间为2.73秒,
SQL124运行时间为0.12秒,如图5)。图5 测试结果 我们把
SQL124放入源代码中,结束一条
SQL语句的
优化工作。从上例可以看到,LECCO
SQL Expert的自动重写技术使原来需要几小时才能完成的
SQL语句的
优化工作,缩减到几
分钟之内就可以完成。
数据库管理员和开发人员可以从繁重的
SQL语句
优化工作中解脱出来。 边做边学式训练 LECCO
SQL Expert不仅能够找到最佳的
SQL语句,而且提供的“边做边学式训练”还能够教会开发人员和
数据库管理员如何写出性能最好的
SQL语句。LECCO
SQL Expert的“
SQL比较器”可以标明源
SQL和待选
SQL之间的不同之处。LECCO
SQL Expert详尽的上下文敏感
帮助系统可以指出
执行计划的深层含义。图6 源语句与
SQL124的比较 以上面
优化的结果为例,为了查看源
SQL语句和
SQL124在写法上的不同,我们可以按下“比较器”按钮,对
SQL124和源
SQL语句进行比较。如果选择“双向比较”复选框,“
SQL比较器”可以将两条互相间的不同之处以蓝色表示。当然,你也可以从 源语句和重写后的
SQL语句中任选两条进行比较(如图6)。 从比较的结果可以看到,重写得到的
SQL124把第一个Exists改写成了In;在字段DPT_ID上进行了合并空字符串的操作以诱导
数据库先
执行子查询中的(SELEC
TDPT_ID||
'FROMDEPART-MENTWH