使用Hint来优化执行计划
最近看主管优化了一个HINT相关的查询
借此机会学习下HINT
参考Notes:
Note 129385 - Database hints in Open SQL
http://www.stechno.net/sap-notes.html?view=sapnote&id=129385
Note 150037 - Database hints in Open SQL for DB6 (DB2 for LUW)
http://www.stechno.net/sap-notes.html?view=sapnote&id=150037
-----------------------------------------------------------------------
概述:
有时查询数据时
查询语句足够复杂
或者使用的二级索引过多
导致的查询方案并不是最好的
所以要手动调整
Hint主要用来优化数据库的查询计划 提高效率
(直接使用native sql的hint应该也是可以的
但是我们这群屌丝开发人员显然对底层数据库的hint使用没把握
会搞这个何苦来做abap >_<
估计也就那几个dba能搞)
使用场景:
1.只能作用在透明表和视图上
缓存表 池表 簇表都是不可以的
2.慎用hint 其他方案不行才使用
并且要保证hint的正确性
3.只有在执行是才能验证是否正确
abap syntax是不检查的
错误的hint导致runtime error
无效的hint可能直接被忽略(看具体底层的数据库)
4.不同数据库使用不同的hint语法
附语法的说明:
前一段大致将%_hint的使用规则
后一段讲述如何定位一个sql中的某一个table
Open SQL notation
In the clause %_HINTS, hints are entered as the last clause of a SELECT, DELETE, UPDATE Open SQL statement or subquery. Hints cannot be entered as SELECT, DELETE or UPDATE in work area statements or other statements:
SELECT [..] FROM [..]
WHERE [..] GROUP BY [..] HAVING [..]
ORDER BY [..]
%_HINTS <selector> '<text>' <selector> '<text>' [..] .
- The %_HINTS clause consists of a list of pairs that consist of a database selector and the actual hint text.
- Selectors are keywords and are therefore not included in '..': ADABAS, AS400, DB2, DB6, INFORMIX, MSSQLNT, ORACLE
- In an actual system, only hint texts with a suitable selector are considered. A hint text is ignored, if it is empty after the evaluation of the substitutions described below or if it only contains blanks.
- A hint text is either a '...' literal character or a character area. If changeable character fields or (FORM-) parameters are entered, the entire statement will become dynamic. In this case a statement cache is more difficult to use.
- You can enter several hint texts per database. The database-specific note mentioned above describes if you can process several hint texts and if so, how you do so.
Text substitutions
The database interface evaluates hint texts before forwarding to a database and carries out some substitutions in these texts.These substitutions are a pure text operation without consideration of the surrounding text. In each case two '&' symbols are used for the compound. Invalid or unknown substitutions result in a runtime error. - && --> &
Technical addition: So that you can enter the character '& ' in a hint text
&TABLE [[<block>,] <table>]& --> <table name>
is replaced with the name which uses the database interface for the entered table opposite the database. Application developers generally do not know this, since the R/3 database interface generates synthetic table aliases of its own accord.
<Table> is the number of a table in the FROM clause, counted from 1, if the FROM clause is read from 'left to right.'The default is '1', that is the first table of the FROM clause.
<Block> specifies which FROM clause is meant: The default '0' specifies the FROM clause of the SELECT..FROM..WHERE block where the hint is also entered. In a subquery '-1', '-2' ... describe the FROM clause of the next outer block along the nesting of blocks/subqueries.
Due to the defaults mentioned above, &TABLE& is synonymous with &TABLE 1& and &TABLE 0,1&.
&table [[<block>,] <table>]& --> < table name>
The same as &TABLE& where upper case is replaced with lower case in the substitution result.
DB2中的两种hint:
1.optimization guidelines
强制使用我们指定的执行计划
SELECT VERSION FROM SVERS
%_HINTS DB6 '<IXSCAN TABLE=''SVERS'' INDEX=''"SVERS~0"'' />' .
forces an index access to the table SVERS using the index SVERS~0.
2.indirect hint
open sql可能是动态的
直接指定有困难
- For dynamic OPEN SQL statements that are converted into different DB2 SQL statements for each execution (for, example, statements with dynamic WHERE clauses, statements with dynamic table names, statements with IN predicates to ABAP range tables), you may not be able to directly influence the DB2 Optimizer using an "Optimization Guideline". In these exceptional cases, you can improve the access plan by using a statement for the SAP database interface (indirect hint).
-------------------------------------------------------------------------------------------
附实际的问题:
(主管优化的代码 优化了很多地方
我估计问题不是出在这里的 但是正好学习下Hint)
在查询采购订单历史的执行计划中
没有使用默认的索引
原因是因为有两个二级索引在
恰好有一个查询条件在一个二级索引中
而Optimizer选择了使用二级索引
现在通过hint指定使用默认索引
使用的是Optimization Guidelines直接指定
估计0就是指定使用默认的索引吧
附代码:
SELECT ebeln ebelp wesbs xblnr shkzg bwart lfpos lfbnr lfgja belnr buzei gjahr
FROM ekbe
INTO CORRESPONDING FIELDS OF TABLE i_ekbe
FOR ALL ENTRIES IN i_mseg
WHERE ebeln = i_mseg-ebeln
AND ebelp = i_mseg-ebelp
AND xblnr = i_mseg-xblnr
and vgabe = '1'
AND bwart IN ('103','104','105','106','124','125')
%_HINTS db6 '<IXSCAN TABLE=''EKBE'' SAP_INDEX=''0''/>'.
使用Hint来优化执行计划的更多相关文章
- SQL Server 优化-执行计划
对于SQL Server的优化来说,优化查询可能是很常见的事情.由于数据库的优化,本身也是一个涉及面比较的广的话题, 因此本文只谈优化查询时如何看懂SQL Server查询计划.毕竟我对SQL Ser ...
- Mysql SQL优化&执行计划
SQL优化准则 禁用select * 使用select count(*) 统计行数 尽量少运算 尽量避免全表扫描,如果可以,在过滤列建立索引 尽量避免在where子句对字段进行null判断 尽量避免在 ...
- MySQL 执行计划详解
我们经常使用 MySQL 的执行计划来查看 SQL 语句的执行效率,接下来分析执行计划的各个显示内容. EXPLAIN SELECT * FROM users WHERE id IN (SELECT ...
- 分析oracle的执行计划(explain plan)并对对sql进行优化实践
基于oracle的应用系统很多性能问题,是由应用系统sql性能低劣引起的,所以,sql的性能优化很重要,分析与优化sql的性能我们一般通过查看该sql的执行计划,本文就如何看懂执行计划,以及如何通过分 ...
- 根据执行计划优化sql语句
优化前:表连接使用merge SQL> alter session set statistics_level=all; Session altered. SQL> select e.sal ...
- 基于Oracle的SQL优化(崔华著)-整理笔记-第2章“Oracle里的执行计划”
详细介绍了Oracle数据里与执行计划有关的各个方面的内容,包括执行计划的含义,加何查看执行计划,如何得到目标SQL真实的执行计划,如何查看执行计划的执行顺序,Oracle数据库里各种常见的执行计划的 ...
- 第九课——MySQL优化之索引和执行计划
一.创建索引需要关注什么? 1.关注基数列唯一键的数量: 比如性别,该列只有男女之分,所以性别列基数是2: 2.关注选择性列唯一键与行数的比值,这个比值范围在0~1之前,值越小越好: 其实,选择性列唯 ...
- mysql之优化器、执行计划、简单优化
mysql之优化器.执行计划.简单优化 2018-12-12 15:11 烟雨楼人 阅读(794) 评论(0) 编辑 收藏 引用连接: https://blog.csdn.net/DrDanger/a ...
- [z]Oracle性能优化-读懂执行计划
http://blog.csdn.net/lifetragedy/article/details/51320192 Oracle的执行计划 得到执行计划的方式 Autotrace例子 ...
随机推荐
- 了解javascript中的this --实例篇
对javascript this的赋值有了深一层的理解后,看一下比较复杂的情况,this的应用篇参考<对javascript this的理解>. #demo1 var name=" ...
- [原创]Microsoft.AnalysisServices.ManagementDialogs.ServerPropertiesLanguagePanel 的类型初始值设定项引发异常
问题: 安装SQL SERVER 2012 SP1后,有可能在右键AS服务器想打开属性面板时候会出现如下错误: 解决: 这个需要安装相应的热修复补丁470544 相应文章: http://smal ...
- HDU 4605 Magic Ball Game 树状数组
题目大意很简单. 有一颗树(10^5结点),所有结点要么没有子结点,要么有两个子结点.然后每个结点都有一个重量值,根结点是1 然后有一个球,从结点1开始往子孙结点走. 每碰到一个结点,有三种情况 如果 ...
- 永远不要在Linux 执行的 10 个最危险的命令
转: http://www.tecmint.com/10-most-dangerous-commands-you-should-never-execute-on-linux/ http://www.l ...
- iOS-UITextField中给placeholder动态设置颜色的四种方法
思路分析: 0.自定义UITextField 1.设置占位文字的颜色找-->placeholderColor,结果发现UITextField没有提供这个属性 2.在storyboard/xib中 ...
- C#实现万年历(农历、节气、节日、星座、属相、生肖、闰年等)
C# 万年历 农历 节气 节日 星座 星宿 属相 生肖 闰年月 时辰等,代码如下: using System.Collections.Generic; using System.Text; using ...
- 使用get方式提交数据
get提交代码 import java.io.InputStream; import java.net.HttpURLConnection; import java.net.MalformedURLE ...
- 安装TortoiseGit出现提示“您必须安装带有更新版本Windows Installer服务的Windows Service Pack”-解决方法
我的系统是xp sp3安装TortoiseGit时出现了错误提示“您必须安装带有更新版本Windows Installer服务的Windows Service Pack”. 解决方法,到微软官方下载相 ...
- [数据结构]字典树(Tire树)
概述: Trie是个简单但实用的数据结构,是一种树形结构,是一种哈希树的变种,相邻节点间的边代表一个字符,这样树的每条分支代表一则子串,而树的叶节点则代表完整的字符串.和普通树不同的地方是,相同的字符 ...
- android studio还不错
今天体验了哈 Android Studio,还不错同Elipse类似