oraclesql中的表明使用变量代替,动态控制查询的表

存储过程中使用sql拼接执行,执行过程完整代码如下。

实现思路是先把变量和字符串拼接成字符串,再调用execute immediate执行字符串。

--oracle 过程中执行拼接的sql
create or replace function fun_huanglijian(in_id varchar2) return varchar2 is
 
  v_sjkb   varchar2(500);
  v_sql    varchar2(5000);
  v_stuname   varchar2(5000);
  v_stusex    varchar2(5000);
 
begin
    select 't_stu' into v_sjkb from dual;        --变量赋值
    --使用变量代表表明拼接到sql字符串中
    v_sql := ' select stuname,stusex from '||v_sjkb||' where stuid = ''1'' ';
    execute immediate v_sql into v_stuname,v_stusex;    --执行sql
    dbms_output.put_line('打印输出'||v_stuname);
    dbms_output.put_line('打印输出'||v_stusex);
    commit;
  return '12';
end;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值