pl/sql的 sql window 如何定义一个变量

我在sqlwindow中使用了一个函数f_getfileid(control_id,dep_code)来得到数据插入表中。现在我希望在其他表中插入这个数据,但f_getf... 我在sql window中使用了一个函数f_getfileid(control_id,dep_code)来得到数据插入表中。现在我希望在其他表中插入这个数据,但f_getfileid()每次返回的值都不一样。希望有个变量保存这个值。sql window可以设变量吗? 如:insert into ly_s_base values((f_getfileid(109,23)),'aa');如果在其他表中插入insert into ly_s_base values((f_getfileid(109,23)),'cc');此f_getfileid()会返回一个新的值。我希望值能不改变改怎么办 展开
 我来答
sun_rain_ice
2012-09-11 · TA获得超过1419个赞
知道小有建树答主
回答量:1286
采纳率:0%
帮助的人:1046万
展开全部
可以把你这个函数贴上来吗?可能是你在不同的数据库下相同名称的数据表,所以取值会变
追问
不是啊,这个函数和 sequence.nextval 差不多啊,每次返回都是加1 的。
追答
明白你什么意思了,除非你把这个数字存在数据表中,不存在用户定义的系统变量(每张表中都能读到的数字)
流浪云风
2012-09-11 · TA获得超过4315个赞
知道大有可为答主
回答量:1119
采纳率:69%
帮助的人:936万
展开全部
在 sql window 中写一个块
declare
v_id varchar2(50); --定义变量
begin
v_id := f_getfileid(control_id,dep_code); --为变量赋值
--以下就是你的其他操作了,比如:
insert into ly_s_base values(v_id ,'aa');
end;
追问
确实可以了。
但下面begin end 中 select into 和 insert into 后,想查看插入的数据 执行select 时会有pls-00428:在此select语句中缺少into子句错误。
追答
plsql块 中不能像sql window中那样select * from table... 也就是说不能显示数据,如果你想看结果,可以使用 DBMS_OUTPUT.PUT_LINE(字符串变量);这个样来打印变量,然后再输出窗口中看到打印结果。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式