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)
PLSQL执行计划
无参数视图:
带参数视图未设置索引:
带参数视图-设置索引:
6.总结
带参数视图-设置索引的执行计划明显比其他两个好看