Oracle认证:ORACLE绑定变量BINDPEEKING
ORACLE 在9i之后引入了bind peeking,通过bind peeking,oracle可以在硬解析的时候窥探绑定变量的值,并根据当前绑定变量的值生成执行计划。在oracle 9i之前的版本中,oracle仅仅通过统计信息来生成执行计划。
下面看一下不同版本oracle下绑定变量对执行计划的影响
SQL> alter system flush shared_pool;
系统已更改。
SQL> alter system set optimizer_features_enable='8.1.7';
系统已更改。
SQL> var v number;
SQL> exec :v := 1;
PL/SQL 过程已成功完成。
SQL> select count(*) from acs_test_tab where record_type = :v;
COUNT(*)
----------
1
SQL> select * from table(dbms_lay_cursor(null,null,'advanced'));
PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
SQL_ID3rg5r8sghcvb3, child number 0
-------------------------------------
select count(*) from acs_test_tab where record_type = :v
Plan hash value: 2956728990
--------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost |
--------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 3 |
| 1 | SORT AGGREGATE | | 1 | 4 | |
|* 2 | INDEX RANGE SCAN| ACS_TEST_TAB_RECORD_TYPE_I | 2 | 8 | 3 |
--------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access("RECORD_TYPE"=:V)
已选择47行。
SQL> alter system flush shared_pool;
系统已更改。
SQL> alter system set optimizer_features_enable='';
系统已更改。
SQL> var v number;
SQL> exec :v := 1;
PL/SQL 过程已成功完成。
SQL> select count(*) from acs_test_tab where record_type = :v;
COUNT(*)
----------
1
SQL> select * from table(dbms_lay_cursor(null,null,'advanced'));
PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
SQL_ID3rg5r8sghcvb3, child number 0
-------------------------------------
select count(*) from acs_test_tab where record_type = :v
Plan hash value: 2956728990
------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 3 (100)| |
| 1 | SORT AGGREGATE | | 1 | 4 | | |
|* 2 | INDEX RANGE SCAN| ACS_TEST_TAB_RECORD_TYPE_I | 1 | 4 | 3 (0)| 00:00:01 |
------------------------------------------------------------------------------------------------
Peeked Binds (identified by position):
--------------------------------------
1 - :V (NUMBER): 1 --绑定变量窥探
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access("RECORD_TYPE"=:V)
已选择49行。
SQL> alter system flush shared_pool;
系统已更改。
SQL> exec :v := 2;
PL/SQL 过程已成功完成。
SQL> select count(*) from acs_test_tab where record_type = :v;
COUNT(*)
----------
50000
SQL> select * from table(dbms_lay_cursor(null,null,'advanced'));
PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
SQL_ID3rg5r8sghcvb3, child number 0
-------------------------------------
select count(*) from acs_test_tab where record_type = :v
Plan hash value: 2957754476
----------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
----------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 136 (100)| |
| 1 | SORT AGGREGATE | | 1 | 4 || |
|* 2 | INDEX FAST FULL SCAN| ACS_TEST_TAB_RECORD_TYPE_I | 48031 | 187K| 136 (1)| 00:00:02 |
-
最强的oracle面试题积累
Oracle公司针对职业教育市场在全球推广的项目,其以低廉的成本给这部分人群提供Oracle技术培训,经过系统化的实训。以下是关于oracle面试题,欢迎大家前来练习!如何转换到spfile?解答:使用createspfilefrompfile命令解释datablock,extent和segment的区别(这里建议用...
-
oracle数据库基本语句
甲骨文公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。下面是小编整理的关于oracle数据库基本语句,欢迎大家参考!1.登陆SPL*PLUS[username/password][@server]as[sysdba|sysoper]eg.system/p...
-
Oracle OCP认证
甲骨文一向都有在第四财季末公布乐观财务数字的传统,公司销售部门在财年末的时候总是喜欢提供大幅折扣提高业绩,以致很多客户会把其采购推迟到5月份以获得很低的价格。下面是小编整理的关于OracleOCP认证,欢迎大家参考!现在欲获得OracleOCP认证的学员,都采取如下两...
-
Oracle DBA回滚段管理精选练习(附答案)
Q.1:Whatsystemprivilegeisrequiredtocreatearollbacksegment?1.Createdatabase2.Createrollbacksegment3.Alterdatabase4.CreatesegmentA:2Q.2:Oraclerecommendsthisnumberofminimumextentsinarollbacksegment1.02.13.24.3A:3Q.3:Oraclerecommendsthatthefollow...
相关文章
- Diaspora Finance Powers Global Development美文欣赏
- Win10系统提示Officebackgroundtaskhandler.exe弹窗问题的解决方
- Modern Technology Makes Life More Conv英语六级作文
- The place of Science and Technology in Modern Life英语作文
- 英语阅读:African Union Leaders Talk Mali, Chinese Investmen
- 英语阅读:VIT declines to acquire Ang Mo Kio property
- Should Private Cars Be Encouraged in China高中英语作文
- 英语满分作文:Reading-TheBestMeanstoAcquireknowledge
- 英语阅读:Covergirl unveils empowering brand update
- 英语阅读范文参考:LovePeopleInAllKindsOfWeather