oracle dw报告,讲解Oracle数据库的全文索引设置步骤

在执行一个SQL之前,首先要分析一下语句的执行计划,然后再按执行计划去执行。分析语句的执行计划的工作是由优化器(Optimizer)来完成的。不同的情况,一条SQL可能有多种执行计划,但在某一时点,一定只有一种执行计划是最优的,花费时间是最少的。相信你一定会用Pl/sql Developer、Toad等工具去看一个语句的执行计划,不过你可能对Rule、Choose、First rows、All rows这几项有疑问,因为我当初也是这样的,那时我也疑惑为什么选了以上的不同的项,执行计划就变了?

1、优化器的优化方式

的优化器共有两种的优化方式,即基于规则的优化方式(Rule-Based Optimization,简称为RBO)和基于代价的优化方式(Cost-Based Optimization,简称为CBO)。

A、RBO方式:优化器在分析SQL语句时,所遵循的是Oracle内部预定的一些规则。比如我们常见的,当一个where子句中的一列有索引时去走索引。

B、CBO方式:依词义可知,它是看语句的代价(Cost)了,这里的代价主要指Cpu和内存。优化器在判断是否用这种方式时,主要参照的是表及索引的统计信息。统计信息给出表的大小 、有少行、每行的长度等信息。这些统计信息起初在库内是没有的,是你在做analyze后才出现的,很多的时侯过期统计信息会令优化器做出一个错误的执行计划,因些我们应及时更新这些信息。在Oracle8及以后的版本,Oracle列推荐用CBO的方式。

我们要明了,不一定走索引就是优的 ,比如一个表只有两行数据,一次IO就可以完成全表的检索,而此时走索引时则需要两次IO,这时对这个表做全表扫描(full table scan)是最好的。

2、优化器的优化模式(Optermizer Mode)

优化模式包括Rule,Choose,First rows,All rows这四种方式,也就是我们以上所提及的。如下我解释一下:

Rule:不用多说,即走基于规则的方式。

Choolse:这是我们应观注的,默认的情况下Oracle用的便是这种方式。指的是当一个表或或索引有统计信息,则走CBO的方式,如果表或索引没统计信息,表又不是特别的小,而且相应的列有索引时,那么就走索引,走RBO的方式。

First Rows:它与Choose方式是类似的,所不同的是当一个表有统计信息时,它将是以最快的方式返回查询的最先的几行,从总体上减少了响应时间。

All Rows:也就是我们所说的Cost的方式,当一个表有统计信息时,它将以最快的方式返回表的所有的行,从总体上提高查询的吞吐量。没有统计信息则走基于规则的方式。

3、如何设定选用哪种优化模式

◆A、Instance级别

我们可以通过在init.ora文件中设定OPTIMIZER_MODE=RULE、OPTIMIZER_MODE=CHOOSE、OPTIMIZER_MODE=FIRST_ROWS、OPTIMIZER_MODE=ALL_ROWS去选用3所提的四种方式,如果你没设定OPTIMIZER_MODE参数则默认用的是Choose这种方式。

◆B、Sessions级别

通过SQL> ALTER SESSION SET OPTIMIZER_MODE=;来设定。

◆C、语句级别

这些需要用到Hint,比如:

SQL> SELECT /*+ RULE */ a.userid,

2 b.name,

3 b.depart_name

4 FROM tf_f_yhda a,

5 tf_f_depart b

6 WHERE a.userid=b.userid;

这个listener还没有配置extproc, 因此,需要为它增加对extproc的监听,办法就是分别增加description 和 sid_desc. 修改后的listner.ora 如下:

[1]

【责编:Ken】

f06.gif相关文章

f06.gif编辑推荐

· []

· []

· []

· []

· []

· []

· []

· []

· []

· []

f04.gif相关产品和培训

f04.gif文章评论

友情推荐链接

·

·

·

·

·

·

·

·

·

·

--------------------next---------------------

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/411436.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 控制台 模拟时间一秒一秒走动,直到按Esc键,时间静止,退出!

Codeusing System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading; //延迟函数必备namespace ConsoleApplication2 { class Program { static void Main(string[] args) { DateTime dt n…

[html] 页面上如何显示特殊字符?

[html] 页面上如何显示特殊字符? 个人简介 我是歌谣,欢迎和大家一起交流前后端知识。放弃很容易, 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

在HTML中插入JavaScript代码的方式

JavaScript代码可以出现在HTML的任何地方(<html>标记之前也可以)。使用<script language”javascript”>javascript代码</script>,但在声明框架的网页中&#xff0c;就一定要在<frameset>之前插入&#xff0c;否则不会运行。另一种方式是将javascript代…

oracle闪回特性,oracle闪回特性

一、闪回查询20:55:03 SQL> select * from emp1;EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO---------- ---------- --------- ---------- ------------ ---------- ---------- ----------7369 SMITH CLERK 7902 …

Python——Django框架——django-simple-captcha(验证码)

一、引用 包 pip install django-simple-captcha 二、将captcha加入setting的 INSTALLED_APPS 三、运行python manager.py migrations 和 python manage.py migrate 四、加入路径 path(captcha/,include(captcha.urls)) 五、引入Form表单 from captcha.fields import CaptchaFi…

[html] 怎样计算首屏和白屏的时间?

[html] 怎样计算首屏和白屏的时间&#xff1f; function showPaintTimings() {if (window.performance) {let performance window.performance;let performanceEntries performance.getEntriesByType(paint);performanceEntries.forEach( (performanceEntry, i, entries) &g…

结构体+sort方法

昨天做了一道简单但很麻烦的题,我只能想到结构体,并用了STL的sort方法解决了它.不过从中有许多细节问题. 题目: Problem Description Lcy wanted to choose 50 ACMers from m players to join HDU-ACM team. He made n competitions , and now is your task to make the rankli…

oracle11gasm,oracle11gASM管理

asmoper和osoper类似都是额外的可选择创建的用户组&#xff0c;创建该独立的用户组以满足赋予用户一套受限的ASM实例管理权限(ASM的SYSOPER角色)&#xff0c;该权限包括了启动和停止ASM 实例&#xff0c;默认情况下OSASM(asmadmin)组成员将拥有所有SYSOPER的ASM管理权限。grid用…

[html] 如何在不同的端口间共享cookie?

[html] 如何在不同的端口间共享cookie&#xff1f; 根据同源策略&#xff0c;cookie是区分端口的&#xff0c;但是浏览器实现来说&#xff0c;“cookie区分域&#xff0c;而不区分端口&#xff0c;也就是说&#xff0c;同一个ip下的多个端口下的cookie是共享的。个人简介 我是…

php 路由 隐藏index,CI中路由与伪静态、隐藏index.php(十四)

1&#xff0c;设置路由默认控制器设置文件application/config/routes.php$route[default_controller] welcome;我们新建一个控制器文件application/controllers/article.php<?php class Article extends CI_Controller{public function index(){echo "这是一个Articl…

更新Linux内核

说明&#xff1a;为了安装Docker&#xff0c;当前虚拟机不满足要求&#xff0c;版本如下&#xff1a; [rootlocalhost116 ~]# uname -r 2.6.32-573.el6.x86_64 [rootlocalhost116 ~]# cat /etc/issue Red Hat Enterprise Linux Server release 6.7 (Santiago) Kernel \r on an …

简单的oracle备份恢复批处理文件 -- 转

建议一&#xff1a; 利用任务计划、批处理文件和ORACLE的EXP导出功能&#xff0c;可以根据日期自动生成ORACLE备份文件&#xff0c;大大方便了ORACLE数据备份。: 1、建立批处理文件backup.bat\. exp system/manager filed:\backup\oracle\oracle%date:~0,10%.dmp ownersystem l…

[html] 使用svg画一个微信的logo

[html] 使用svg画一个微信的logo <svg xmlns"http://www.w3.org/2000/svg" version"1.1"><!--绿色大椭圆下的小尾巴--><polygon points"70,92 85,97 65,107"style"fill:#84d845;"/><!--绿色大椭圆--><ell…

web项目jsp中无法引入js问题

https://blog.csdn.net/C1042135353/article/details/80274685#commentBox 这篇文章超赞的&#xff0c;几个小时的时间看了这篇文章豁然开朗&#xff0c;瞬间懂了。 转载于:https://www.cnblogs.com/c-lover/p/10869000.html

软件开发人员想找的工作,随便聊聊,娱乐大家,请补充补充

01. 工作环境好&#xff0c;大公司&#xff0c;很有名气的。02. 最好是新投资软件行业的老板&#xff0c;舍得烧钱&#xff0c;老板越不懂行越好。03. 公司最好是不加班&#xff0c;周末双休&#xff0c;出差有补贴&#xff0c;节假日都休息&#xff0c;每年还有法定年休&#…

oracle字符nul怎么输入,oracle - 如何摆脱Oracle数据库中的NUL字符? - 堆栈内存溢出...

就个人而言&#xff0c;我会使用CHR()来识别零值。 nul是ASCII 0&#xff0c; CHR()将返回您传入的数字的字符表示。SQL> with the_data as (2 select a || chr(0) || b as str from dual3 union all4 select a || c from dual5 )6 select dump(str)7 from the_data8 where …

[html] 为什么我们要使用web workers?

[html] 为什么我们要使用web workers&#xff1f; 因为js是单线程&#xff0c;如果存在大数据运算的时候会影响用户使用体验&#xff0c;出现卡顿的情况。 使用web workers 可以开启一个线程&#xff0c;在运算的同时&#xff0c;不影响用户体验。 web workers的几个使用场景可…

VRTK射线检测

VRTK射线检测回调事件 本人在工作中做VR隐患排查项目开发的时候&#xff0c;有个功能需要做到&#xff1a;按下手柄触摸板发送射线&#xff0c;松开触摸板的时候处理射线最后检测到的那个游戏物体。 功能构思&#xff1a;1、按下触摸板&#xff0c;从手柄上发射射线&#xff1b…

SELECT命令中的GROUPBY和HAVING子句

在介绍GROUP BY 和 HAVING 子句前&#xff0c;我们必需先讲讲sql语言中一种特殊的函数&#xff1a;聚合函数&#xff0c;例如SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。 SELECT SUM(population) FROM bbc 这里的SUM作用在所有返回记…

发布任务PHP源码,Thinkphp5新威客任务平台源码

最新更新日志 修复注册时提示验证码错误的BUG修复Thinkphp框架漏洞兼容linux去除冗余代码和无用文件功能模块 1.手机任务面&#xff0c;一个手机版的任务需要&#xff0c;支持雇主入住发布任务&#xff0c;用户是雇主也是做任务可以自己发任务&#xff0c;做任务。2.雇主发布任…