0

0

Oracle 自适应游标共享--adaptive cursor sharing

php中文网

php中文网

发布时间:2016-06-07 17:34:39

|

1275人浏览过

|

来源于php中文网

原创

在11g中,Oracle引入了一项新特征:adaptive cursor sharing 自适应游标共享。这项特征主要用来改进具有绑定变量的sql语句的执行

在11g中,oracle引入了一项新特征:adaptive cursor sharing 自适应游标共享。这项特征主要用来改进具有绑定变量的sql语句的执行计划,也导致了具有绑定变量的sql语句可能会生成多个游标。在9i中,oracle引入了变量窥测(bind peeking)技术,通过使用变量窥测在sql语句第一次硬解析时,优化器可以判定where子句的选择性,从而改进生成执行计划的质量。但是使用变量窥测技术生成的执行计划在表数据分布不均衡的情况下,往往不具有通用性。(参见:)

自适应游标共享功能的引入,可以有效的解决这个问题。

首先看一下我们的测试环境:

SQL> desc acs_test_tab
 名称            是否为空? 类型
 ----------------------------------------------------- -------- ------------------------------------
 ID            NOT NULL NUMBER
 RECORD_TYPE       NUMBER
 DESCRIPTION       VARCHAR2(50)

SQL> select count(*) from acs_test_tab;

  COUNT(*)
----------
    100000

SQL> select count(*) from acs_test_tab where record_type=2;

  COUNT(*)
----------
    50000

SQL> select count(distinct record_type) from acs_test_tab;

COUNT(DISTINCTRECORD_TYPE)
--------------------------
      50001

表acs_test_Tab在列record_type上分布式是倾斜的。收集统计信息:

SQL> exec dbms_stats.gather_Table_Stats(user,'acs_test_Tab',cascade=>true,method_opt=>'for all columns size auto');

PL/SQL 过程已成功完成。

SQL> select column_name,histogram from user_tab_cols where table_name='ACS_TEST_TAB';

COLUMN_NAME        HISTOGRAM
------------------------------ ---------------
ID          NONE
RECORD_TYPE        HEIGHT BALANCED
DESCRIPTION        NONE

首先我们对record_type 为1 的列进行查询

SQL> select count(*) from acs_test_tab where record_type = 1;

  COUNT(*)
----------
  1

SQL> alter system flush shared_pool;

系统已更改。

SQL> var v number;
SQL> exec :v := 1

PL/SQL 过程已成功完成。

SQL> select sum(id) from acs_test_tab where record_type = :v;

  SUM(ID)
----------
  1

SQL> select * from table(dbms_xplan.display_cursor);

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------------------------------------------------------------------
SQL_ID 3p66zbwtm19bs, child number 0
-------------------------------------
select sum(id) from acs_test_tab where record_type = :v

Plan hash value: 3987223107

百度作家平台
百度作家平台

百度小说旗下一站式AI创作与投稿平台。

下载

-----------------------------------------------------------------------------------------------------------
| Id  | Operation      | Name    | Rows  | Bytes | Cost (%CPU)| Time  |
-----------------------------------------------------------------------------------------------------------
|  0 | SELECT STATEMENT      |      |  |  | 4 (100)|  |
|  1 |  SORT AGGREGATE       |      | 1 | 9 |        |  |
|  2 |  TABLE ACCESS BY INDEX ROWID| ACS_TEST_TAB    | 1 | 9 | 4  (0)| 00:00:01 |
|*  3 |    INDEX RANGE SCAN      | ACS_TEST_TAB_RECORD_TYPE_I | 1 |  | 3  (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

  3 - access("RECORD_TYPE"=:V)


已选择20行。

SQL> select child_number,executions,buffer_gets,is_bind_sensitive,is_bind_aware
  2  from v$sql
  3  where sql_text like 'select sum(id)%';

CHILD_NUMBER EXECUTIONS BUFFER_GETS I I
------------ ---------- ----------- - -
    0      1  218 Y N

下面我们在查询一下record_type为2的记录,

SQL> exec :v := 2

PL/SQL 过程已成功完成。

SQL> select sum(id) from acs_test_tab where record_type = :v;

  SUM(ID)
----------
2500050000

SQL> select * from table(dbms_xplan.display_cursor);

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------------------------------------------------------------------
SQL_ID 3p66zbwtm19bs, child number 0
-------------------------------------
select sum(id) from acs_test_tab where record_type = :v

Plan hash value: 3987223107

-----------------------------------------------------------------------------------------------------------
| Id  | Operation      | Name    | Rows  | Bytes | Cost (%CPU)| Time  |
-----------------------------------------------------------------------------------------------------------
|  0 | SELECT STATEMENT      |      |  |  | 4 (100)|  |
|  1 |  SORT AGGREGATE       |      | 1 | 9 |        |  |
|  2 |  TABLE ACCESS BY INDEX ROWID| ACS_TEST_TAB    | 1 | 9 | 4  (0)| 00:00:01 |
|*  3 |    INDEX RANGE SCAN      | ACS_TEST_TAB_RECORD_TYPE_I | 1 |  | 3  (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

  3 - access("RECORD_TYPE"=:V)


已选择20行。

SQL> select child_number,executions,buffer_gets,is_bind_sensitive,is_bind_aware
  2  from v$sql
  3  where sql_text like 'select sum(id)%';

CHILD_NUMBER EXECUTIONS BUFFER_GETS I I
------------ ---------- ----------- - -
    0      2  832 Y N

我们发现执行计划没有变化,但是统计信息却发生了比较大的跳跃。

再次执行上面的语句

SQL> select sum(id) from acs_test_tab where record_type = :v;

  SUM(ID)
----------
2500050000

SQL> select * from table(dbms_xplan.display_cursor);

相关专题

更多
Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

6

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

101

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

55

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

12

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

85

2026.01.09

漫蛙稳定版地址大全
漫蛙稳定版地址大全

漫蛙稳定版地址大全汇总最新可用入口,包含漫蛙manwa漫画防走失官网链接,确保用户随时畅读海量正版漫画资源,建议收藏备用,避免因域名变动无法访问。

444

2026.01.09

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

49

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.4万人学习

Java 教程
Java 教程

共578课时 | 45.1万人学习

布尔教育燕十八mysql高级视频教程
布尔教育燕十八mysql高级视频教程

共24课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号