使用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例子 ...
随机推荐
- 终端I/O之波特率函数
波特率(baud rate)是一个以往采用的术语,现在它指的是"位/秒"(bits per second).虽然大多数终端设备对输入和输出使用同一波特率,但是只要硬件许可,可以将它 ...
- LeetCode39 Combination Sum
题目: Given a set of candidate numbers (C) and a target number (T), find all unique combinations in C ...
- python 操作word文档
因为工作需要操作一些word文档,记录一下学习思路 #-*- encoding: utf8 -*- import win32com from win32com.client import Dispat ...
- 自定义强大的C#网络操作基础类(NetHelper)
using System; using System.Text;using System.Net.Sockets;using System.Net.Mail;using System.Net; nam ...
- Good subsequence( RMQ+二分)
Description Give you a sequence of n numbers, and a number k you should find the max length of Good ...
- DataGridView 多线程更新 数据 解决卡顿问题
使用多线程更新DataGridView,防止页面卡顿和卡死的问题 private delegate void UpdateDataGridView(DataTable dt); private voi ...
- Windows配置端口转发
windows命令行下用netsh实现端口转发 微软Windows的netsh是一个命令行脚本实用工具.使用netsh工具 ,可以查看或更改本地计算机或远程计算机的网络配置.不仅可以在本地计算机上运行 ...
- uva 10054 The Necklace 拼项链 欧拉回路基础应用
昨天做了道水题,今天这题是比较水的应用. 给出n个项链的珠子,珠子的两端有两种颜色,项链上相邻的珠子要颜色匹配,判断能不能拼凑成一天项链. 是挺水的,但是一开始我把整个项链看成一个点,然后用dfs去找 ...
- vb.net中的SqlHelper
1.定义: SqlHelper是一个基于·NET Framework的数据库操作组件.组件中包含数据库操作方法.SqlHelper用于简化你重复的去写那些数据库连接(SqlConnection),Sq ...
- svn配置
svn配置 subverson.conf <Location /svn> DAV svn SVNListParentPath on SVNParentPath /var/repo Auth ...