最近看主管优化了一个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可能是动态的

直接指定有困难 

  1. 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来优化执行计划的更多相关文章

  1. SQL Server 优化-执行计划

    对于SQL Server的优化来说,优化查询可能是很常见的事情.由于数据库的优化,本身也是一个涉及面比较的广的话题, 因此本文只谈优化查询时如何看懂SQL Server查询计划.毕竟我对SQL Ser ...

  2. Mysql SQL优化&执行计划

    SQL优化准则 禁用select * 使用select count(*) 统计行数 尽量少运算 尽量避免全表扫描,如果可以,在过滤列建立索引 尽量避免在where子句对字段进行null判断 尽量避免在 ...

  3. MySQL 执行计划详解

    我们经常使用 MySQL 的执行计划来查看 SQL 语句的执行效率,接下来分析执行计划的各个显示内容. EXPLAIN SELECT * FROM users WHERE id IN (SELECT ...

  4. 分析oracle的执行计划(explain plan)并对对sql进行优化实践

    基于oracle的应用系统很多性能问题,是由应用系统sql性能低劣引起的,所以,sql的性能优化很重要,分析与优化sql的性能我们一般通过查看该sql的执行计划,本文就如何看懂执行计划,以及如何通过分 ...

  5. 根据执行计划优化sql语句

    优化前:表连接使用merge SQL> alter session set statistics_level=all; Session altered. SQL> select e.sal ...

  6. 基于Oracle的SQL优化(崔华著)-整理笔记-第2章“Oracle里的执行计划”

    详细介绍了Oracle数据里与执行计划有关的各个方面的内容,包括执行计划的含义,加何查看执行计划,如何得到目标SQL真实的执行计划,如何查看执行计划的执行顺序,Oracle数据库里各种常见的执行计划的 ...

  7. 第九课——MySQL优化之索引和执行计划

    一.创建索引需要关注什么? 1.关注基数列唯一键的数量: 比如性别,该列只有男女之分,所以性别列基数是2: 2.关注选择性列唯一键与行数的比值,这个比值范围在0~1之前,值越小越好: 其实,选择性列唯 ...

  8. mysql之优化器、执行计划、简单优化

    mysql之优化器.执行计划.简单优化 2018-12-12 15:11 烟雨楼人 阅读(794) 评论(0) 编辑 收藏 引用连接: https://blog.csdn.net/DrDanger/a ...

  9. [z]Oracle性能优化-读懂执行计划

    http://blog.csdn.net/lifetragedy/article/details/51320192 Oracle的执行计划   得到执行计划的方式       Autotrace例子 ...

随机推荐

  1. MySQL中内存分为全局内存和线程内存

    首先我们来看一个公式,MySQL中内存分为全局内存和线程内存两大部分(其实并不全部,只是影响比较大的 部分): 复制代码 代码如下: per_thread_buffers=(read_buffer_s ...

  2. GDB---Oracle Function Call List

    http://yong321.freeshell.org/Oracle Function Call List 1. Oracle function call list If you want to s ...

  3. 使用Linux的mail命令发送邮件

    由于经常工作在linux下,所以很多时候需要将自己工作的报告或其他有用的东东发送给相关的人,所以花时间研究了一下在linux下如何发送mail.我们通常能用到下面3中发送方式: 1. 使用Shell当 ...

  4. 构建高性能服务(三)Java高性能缓冲设计 vs Disruptor vs LinkedBlockingQueue--转载

    原文地址:http://maoyidao.iteye.com/blog/1663193 一个仅仅部署在4台服务器上的服务,每秒向Database写入数据超过100万行数据,每分钟产生超过1G的数据.而 ...

  5. 内核链表list.h

    stddef.h #define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER) list.h #ifndef _LINUX ...

  6. 关于Android(Java)创建匿名线程

    Java中创建匿名线程主要集中就三中方式:Thread,Runnable,Handler去实现,下面分别介绍之- 一.通过Thread来创建 new Thread() { public void ru ...

  7. C++与正态分布

    正态分布(Normal distribution)又名高斯分布(Gaussiandistribution).若随机变量X服从一个数学期望为μ.方差为σ^2的高斯分布,记为N(μ,σ^2).其概率密度函 ...

  8. hadoop2 作业执行过程之作业提交

    hadoop2.2.0.centos6.5 hadoop任务的提交常用的两种,一种是测试常用的IDE远程提交,另一种就是生产上用的客户端命令行提交 通用的任务程序提交步骤为: 1.将程序打成jar包: ...

  9. Handler发送消息

    Handler发送消息小结 字数283 阅读210 评论0 喜欢1 obtainMessage()得到一个Message对象. 创建一个Message然后发送是这么写的: Message msg = ...

  10. windows获取时间的方法

    介绍       我们在衡量一个函数运行时间,或者判断一个算法的时间效率,或者在程序中我们需要一个定时器,定时执 行一个特定的操作,比如在多媒体中,比如在游戏中等,都会用到时间函数.还比如我们通过记录 ...