Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1339475
  • 博文数量: 169
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 3800
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-30 13:00
个人简介

About me:Oracle ACE pro,optimistic,passionate and harmonious. Focus on ORACLE,MySQL and other database programming,peformance tuning,db design, j2ee,Linux/AIX,Architecture tech,etc

文章分类

全部博文(169)

文章存档

2024年(24)

2023年(28)

2022年(43)

2020年(62)

2014年(3)

2013年(9)

分类: Oracle

2023-05-09 23:07:29

1)DETERMINISTIC不建立索引,缓存无效,执行的时候还是调用函数,
--自定义函数,要建立索引,必须有DETERMINISTIC关键字,否则不确定不可以
dingjun123@ORADB> create or replace function func_tt(x in varchar2)
  2      return varchar2 DETERMINISTIC
  3    as
  4     begin
  5       DBMS_APPLICATION_INFO.set_client_info(USERENV('client_info')+1 );
  6     return 'a'||x;
  7    end;
  8   /


函数已创建。


已用时间:  00: 00: 00.26
dingjun123@ORADB> drop table t;


表已删除。


已用时间:  00: 00: 01.62
dingjun123@ORADB>  create table t(m varchar2(100) not null);


表已创建。


已用时间:  00: 00: 00.37
dingjun123@ORADB>  insert into t select level from dual connect by level<1000;


已创建999行。


已用时间:  00: 00: 00.04
dingjun123@ORADB> commit;


提交完成。


已用时间:  00: 00: 00.04
dingjun123@ORADB> EXEC DBMS_APPLICATION_INFO.set_client_info(0);


PL/SQL 过程已成功完成。


已用时间:  00: 00: 00.00
dingjun123@ORADB> SELECT USERENV('client_info') FROM DUAL;


USERENV('CLIENT_INFO')
----------------------------------------------------------------
0


已选择 1 行。


已用时间:  00: 00: 00.01
dingjun123@ORADB> select * from t where func_tt(m)='a2';


M
----------------------------------------------------------------------------------------------------
2


已选择 1 行。


已用时间:  00: 00: 00.04
dingjun123@ORADB> SELECT USERENV('client_info') FROM DUAL;


USERENV('CLIENT_INFO')
----------------------------------------------------------------
999


已选择 1 行。


已用时间:  00: 00: 00.01
dingjun123@ORADB> select * from t where func_tt(m)='a2';


M
----------------------------------------------------------------------------------------------------
2


已选择 1 行。


已用时间:  00: 00: 00.03
dingjun123@ORADB> SELECT USERENV('client_info') FROM DUAL;


USERENV('CLIENT_INFO')
----------------------------------------------------------------
1998


已选择 1 行。


已用时间:  00: 00: 00.00




2.DETERMINISTIC+索引才能缓存,执行的时候不再调用函数
DINGJUN123>create or replace function func_tt(x in varchar2)
  2      return varchar2 DETERMINISTIC
  3      as
  4      begin
  5      DBMS_APPLICATION_INFO.set_client_info(USERENV('client_info')+1 );
  6       return 'a'||x;
  7      end;
  8  /


函数已创建。


DINGJUN123> drop table t;


表已删除。


DINGJUN123> create table t(m varchar2(100) not null);


表已创建。


DINGJUN123> insert into t select level from dual connect by level<1000;


已创建999行。


DINGJUN123> commit;


提交完成。


DINGJUN123>EXEC DBMS_APPLICATION_INFO.set_client_info(0);


PL/SQL 过程已成功完成。


DINGJUN123>create index idx_t on t (func_tt(m));


索引已创建。


DINGJUN123> exec    dbms_stats.gather_table_stats(user,'t',cascade => true);


PL/SQL 过程已成功完成。


--这里创建索引,函数就被调用很多次了




DINGJUN123> SELECT USERENV('client_info') FROM DUAL;


USERENV('CLIENT_INFO')
---------------------------------------------------------------------------------------------------------
5994


已选择 1 行。




DINGJUN123> select * from t where func_tt(m)='a2';


M
---------------------------------------------------------------------------------------------------------
2


已选择 1 行。


--不需要再调用函数


DINGJUN123> SELECT USERENV('client_info') FROM DUAL;


USERENV('CLIENT_INFO')
---------------------------------------------------------------------------------------------------------
5994


已选择 1 行。

阅读(562) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~