oracle procedure存储过程输入参数用于sql like模糊匹配2算法

 
SQL> select * from t_like;
 
A
--------------------------------------------------------------------------------
山西省
北京
 北京
 
 
 
SQL> create or replace procedure proc_like(in_a varchar2)
  2  as
  3  v_sql varchar2(4000);
  4  begin
  5  v_sql:='select a from t_like where a like '||''''||'%'||in_a||'%'||'''';
  6  dbms_output.put_line(v_sql);
  7  end;
  8  /
 
Procedure created
 
 
SQL> exec proc_like('北京');
 
select a from t_like where a like '%北京%'
 
PL/SQL procedure successfully completed
 
SQL> select a from t_like where a like '%北京%';
 
A
--------------------------------------------------------------------------------
北京
 北京
 
 
SQL> create or replace procedure proc_like_instr(in_a varchar2)
2 as
3 v_sql varchar2(4000);
4 begin
5 v_sql:='select a from t_like where instr(a,in_a)>0
  6 dbms_output.put_line(v_sql);
7 end;
8 /

Procedure created
 
小结:instr效率高于动态拼接sql,因为动态拼接每次要硬解析
最好思考用函数实现存储过程的功能而非动态sql

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9240380/viewspace-753202/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/9240380/viewspace-753202/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值