ORACLE 创建带参数视图-实践

PS:最近在做一个需求,移交A人多个业务表(7个)的数据给另几个人(就是查询出A的业务数据,把相应字段改成其他人),想到的办法就是创建一个视图union all 所有业务表。根据A编号去查询业务数据,所以考虑通过每个业务表加上客户编号去过滤数据,提高查询性能。但是这个客户编号是动态的,使用普通视图就不能在每个业务表过滤了,在网上查询,视图是可以带参数的,所以实践下,并记录。

下面是使用步骤:

1.创建一个package,包中定义两个方法,一个set值的方法,一个get值的方法

 --定义包
create or replace package view_move_user is
  --set值方法
  function set_moveuser(moveuser varchar2) return varchar2;
  --get值方法
  function get_moveuser return varchar2;
end view_move_user;

2.创建package body,实现package中的两个方法

--包方法实现
create or replace package body view_move_user is
  paramValue varchar2(32);
  -- 给paramValue赋值
  function set_moveuser(moveuser varchar2) return varchar2 is
  begin
    paramValue := moveuser;
    return moveuser;
  end;
 --返回paramValue 的值
  function get_moveuser return varchar2 is
  begin
    return paramValue;
  end;

end view_move_user;

3.创建带参数视图view_move_user.get_moveuser()是从方法中获取传入的参数

Create View view_move1 As select busi_segment,busi_id,move_user from (
select '005' as busi_segment,
       archive_id as busi_id,
       loan_com_id as move_user
  from Doc_Archive
 where archive_type = '1'
   and is_temp is null
   and loan_com_id=view_move_user.get_moveuser()
   union all
   select '004' as busi_segment,
       staging_id as busi_id,
       loan_com_id as move_user
  from Doc_Staging
 where status <> '5'
  and loan_com_id=view_move_user.get_moveuser()
 union all 
 select '003' as busi_segment,
       loan_input_id  as busi_id,
       confirmer_id as move_user
  from Pvp_Loan_Input
 where input_status <> '30'
 and confirmer_id=view_move_user.get_moveuser()
 union all 
 select '002' as busi_segment,
       loan_no   as busi_id,
       loan_com_id as move_user
  from Pvp_Loan_Apply
 where approve_status not in( '000','990','998')
  and loan_com_id=view_move_user.get_moveuser()
 union all 
 select '001' as busi_segment,
       cont_no    as busi_id,
       loan_com_id as move_user
  from Ctr_Cont_Apply
 where approve_status not in( '000')
   and loan_com_id=view_move_user.get_moveuser()
 union all 
 select '006' as busi_segment,
       task_id      as busi_id,
       loan_com_id as move_user
  from Pvp_Repay_Fee_Make
 where approve_status  ='000'
       and loan_com_id=view_move_user.get_moveuser()
 union all 
 select '007' as busi_segment,
       sign_input_id     as busi_id,
       cont_sign_user as move_user
  from Ctr_Sign
 where input_status ='10'
   and cont_sign_user=view_move_user.get_moveuser()

);


4.查询视图语句view_move_user.set_moveuser('20805') ='20805' 通过set方法,传入20805

select * from view_move1 where view_move_user.set_moveuser('20805') ='20805' ;

5.根据PLSQL查看执行效率(取本次最多数据量的数据5775,分别执行5次,单位:s)

ORACLE 创建带参数视图-实践_第1张图片

PLSQL执行计划

无参数视图:

ORACLE 创建带参数视图-实践_第2张图片


带参数视图未设置索引:

ORACLE 创建带参数视图-实践_第3张图片


带参数视图-设置索引:

ORACLE 创建带参数视图-实践_第4张图片

6.总结

带参数视图-设置索引的执行计划明显比其他两个好看

你可能感兴趣的:(其他技术经验)