oracle 中怎样把查询结果当做已知量或赋值给某个变量?

如我想在update station
set geom=addpoint(x,y,z)where id=1
中将x,y的位置用另一个表的某行的两个值代替应该怎么操作啊,谢谢了
代码如图
最新回答
号订婚

2024-11-22 10:21:50

需要写存储过程,先声明两个变量v_x,v_y,然后用select into语句赋值给这两个变量.以下供参考:
declare
v_x NUMBER; --必须和addpoint(x,y,z)里面的x字段类型一致
v_y NUMBER; --必须和addpoint(x,y,z)里面的y字段类型一致
...
begin
select xxx,yyy into v_x, v_y from table; --把table表中xxx,yyy的值赋给v_x,v_y.你可以自己写查询
...
update station set set geom=addpoint(v_x,v_y,z)where id=1;
...
end
追问
SQL> create or replace procedure pro_into
as
declare
v_x number;
v_y number;
begin
select sta_long into v_x from sta_87 where id=2;
select sta_alt into v_y from sta_87 where id=2;
update station_87
set geom= addpoint(v_x,v_y,4214)where id=2;
end pro_into;
/
Warning: Procedure created with compilation errors
就报错了,帮忙看看有哪不对吗?多给分哦
追答
set geom= addpoint(v_x,v_y,4214)where id=2;
4214)后面是否要加一个空格
逼啵逼啵

2024-11-22 13:52:19

加个判断就好了,可以用自带的异常。 EXCEPTION WHEN NO_DATA_FOUND THEN 变量 = NULL; END ;
风清淡雅

2024-11-22 19:45:40

存储过程里面定义局部变量不需要declare ,去掉declare 试试。
逗妇恼

2024-11-22 14:18:23

update station set geom=addpoint(sta_87.sta_long,sta_87.sta_alt,z)where id=1
这样不行么?
追问
TT 也不行,说是标示符无效,是不是我的pl/sql developer版本不对啊?
追答
你确定表名都对吧?
你那个_87都加了?
或者是都不用加?
追问
表名都对,大侠方便加下我qq吗1269160297
追答
额...非大侠,只是凭经验的一点推论,oracle不是很瘦
公司无法聊Q,*_*