ORACLE存储过程的问题: 假设有A表,B表和C表,B表和C表是一样的字段,要把B表或者C表的数据插入到A表

需要传入参数有:表名,和日期时间(字符串类型的)假设A表和B表和C表中都有有name,id,date几个字段createorreplaceprocedureP_NAME(... 需要传入参数有:表名,和日期时间(字符串类型的)
假设A表和B表和C表中都有有name,id,date几个字段

create or replace procedure
P_NAME(ret out number,table_name in char, Dt in char)
is
begin
execute immediate '
insert into A(name,id,date)
select name,id,date from ' ||table_name|| ‘where date =’ || Dt;
commit;
end;

运行有问题。求解答。
展开
 我来答
ling78714
2012-10-16
知道答主
回答量:14
采纳率:0%
帮助的人:9.7万
展开全部
授之以鱼不如授之以渔把,这类问题的调试都有一个标准方法,就是先把这句拼接的SQL字符串放入到一个定义的变量里,把这个变量返出来,或者DBMS.OUTPUT日志打出来,看看语句是否有问题,或者标点或者空格都有可能。具体你只要把打印出来的SQL语句单独执行下,根据错误提示就知道错误出在那了。然后在回去改拼接SQL语句的地方,如此往复,再复杂的SQL语句拼接也能够搞定。另外如果是通过游标循环生成的大SQL语句,建议存放在long类型变量中,因为一般的VACHAR2之类的字符类型会不够长,截断后面的语句,同样也会导致语句错误
百度网友0319a0e
2012-10-16 · TA获得超过2.2万个赞
知道小有建树答主
回答量:2080
采纳率:85%
帮助的人:1133万
展开全部
create or replace procedure
P_NAME(ret out number,table_name in char, Dt in char)
is
v_sql varchar2(300);
begin
v_sql:='insert into A(name,id,date)
select name,id,date from ' ||table_name||‘ where date =’ || Dt;
execute immediate v_sql;
Commit;
end;
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
邓友谊_by3g
2012-10-16
知道答主
回答量:34
采纳率:0%
帮助的人:23.8万
展开全部
create or replace procedure
is
begin
insert into A as select * from B or select * from C;
execute immediate v_sql;
Commit;
end;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
游龙玉
2012-10-16 · 超过13用户采纳过TA的回答
知道答主
回答量:39
采纳率:0%
帮助的人:6.2万
展开全部
execute immediate '
insert into A(name,id,date)
select name,id,date from '||table_name||' where date ='|| Dt;
注意标点符号及空格where 前不加空格,会和表名连一起
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
情又独中
2012-10-16 · TA获得超过1032个赞
知道小有建树答主
回答量:1220
采纳率:100%
帮助的人:811万
展开全部
报错信息贴出来
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式