假设我有一个包含 a、b、c、d、e 列的表
有没有一种方法/语法可以从过程/函数的 out 参数中更新 d 和 e 列,该过程/函数接受 a、b 和 c 列的参数值。(程序(a, b, c, out d, out e))
(除了使用游标一一遍历所有行)?
您可以创建一个PL/SQL 表或用户定义的记录,就像这样
处理记录的功能
FUNCTION Get_updated_recs(p_emp_id emp.emp_id%TYPE,
p_manager_id emp.manager_id%TYPE)
RETURN EMP_REC_TYPE
IS
p_emp_rec EMP_REC_TYPE;
BEGIN
IF p_emp_id = 100 THEN
p_emp_rec.salary := 50000;
p_emp_rec.bonus := 10000;
END IF;
RETURN p_emp_rec;
END get_updated_recs;
主程序单元
DECLARE
TYPE emp_rec_type IS RECORD (
salary employees.salary%TYPE,
bonus employees.bonus );
emp_rec EMP_REC_TYPE;
BEGIN
FOR emp IN (SELECT *
FROM employees) LOOP
emp_rec := Get_updated_recs(emp.emp_id, emp.manager_id);
UPDATE employees
SET salary = emp_rec.salary,
bonus = emp_rec.bonus
WHERE emp_id = emp.emp_id;
END LOOP;
END;
我没有测试/编译它,只是写出了我的记忆,但这样的东西应该可以工作
在 Oracle 专家的帮助下,我得出了以下解决方案:
CREATE TABLE testtable
(
a number,
b number,
c number,
d number
);
CREATE TYPE testobj AS OBJECT
(
x number,
y number
);
CREATE OR REPLACE FUNCTION testfun(a number, b number)
RETURN testobj IS
begin
return new testobj(x=>a+b, y=> a*b);
end;
INSERT INTO testtable VALUES (1,2,null,null);
INSERT INTO testtable VALUES (5,6,null,null);
UPDATE
(SELECT tt.*,
testfun1(a,b) fun_ret FROM testtable tt) talias
SET talias.c=talias.fun_ret.x,
talias.d=talias.fun_ret.y
;
执行以下操作:
(1) 创建并填写示例表:
CREATE TABLE TEST1
(
a NUMBER(10), b number (10), s number (10)
);
INSERT INTO TEST1 (a, b, s) VALUES (2, 3, NULL);
INSERT INTO TEST1 (a, b, s) VALUES (3, 12, NULL);
INSERT INTO TEST1 (a, b, s) VALUES (-2, 8, NULL);
(2) 为在 UPDATE 命令中使用创建一个简单的函数:
CREATE OR REPLACE FUNCTION GET_SUM (x IN NUMBER, y IN NUMBER)
RETURN NUMBER
IS
x1 NUMBER(10) := x; y1 NUMBER (10):= y; s NUMBER(10) := NULL;
BEGIN
IF x1 IS NOT NULL AND y1 IS NOT NULL THEN s := x1 + y1; END IF;
RETURN s;
END;
(3) 在下面的 UPDATE 命令中使用这个函数:
UPDATE TEST1 SET s = GET_SUM (a, b);
(4) 检查更新:
select * from TEST1;