我做了一个例子来更好地解释这种情况:
我有两张桌子
CREATE TABLE AA
(
ID NUMBER NOT NULL PRIMARY KEY,
REFERENCE NVARCHAR2(100) NULL
)
CREATE TABLE BB
(
ID NUMBER NOT NULL PRIMARY KEY,
IDA NUMBER NOT NULL,
REFERENCE NVARCHAR2(100) NULL,
FOREIGN KEY (IDA) REFERENCES AA(ID)
)
和一些记录
INSERT INTO AA VALUES(1, NULL)
INSERT INTO AA VALUES(2, NULL)
INSERT INTO AA VALUES(3, NULL)
INSERT INTO AA VALUES(4, NULL)
INSERT INTO AA VALUES(5, NULL)
INSERT INTO BB VALUES(6, 1, 'AAA')
INSERT INTO BB VALUES(7, 2, 'BBB')
INSERT INTO BB VALUES(8, 3, 'CCC')
我必须将REFERENCE
的{{1}}字段设置为AA
BB
中IDA
的值。
所以我决定使用游标
DECLARE
idA NUMBER;
reference NVARCHAR2(100);
CURSOR ref_cursor
IS
SELECT IDA, REFERENCE FROM BB;
BEGIN
OPEN ref_cursor;
LOOP
FETCH ref_cursor into idA, reference;
EXIT WHEN ref_cursor%NOTFOUND;
UPDATE AA
SET REFERENCE = reference
WHERE ID = idA;
DBMS_OUTPUT.put_line('reference of movement ' || idA || ' updated with ' || reference);
END LOOP;
CLOSE ref_cursor;
END;
通过执行它,我得到一个输出
reference of movement 1 updated with AAA
reference of movement 2 updated with BBB
reference of movement 3 updated with CCC
这正是我想要的,但是当我通过星形选择表检查数据时,我发现REFERENCE
列仍然是NULL
。
所以我找到了另一个光标
DECLARE
CURSOR ref_cursor
IS
SELECT IDA, REFERENCE FROM BB;
BEGIN
FOR ref_c IN ref_cursor
LOOP
UPDATE AA SET REFERENCE = ref_c.REFERENCE WHERE ID = ref_c.IDA;
END LOOP;
END;
这个实际上正在进行更新。为什么这两个游标不同?
答案 0 :(得分:1)
在PL / SQL块内处理SQL语句时,SQL名称解析优先,因此表字段优先于具有相同名称的变量。要解决此问题,您有两种方法:
更改变量名称。
在第二个查询中添加前缀到变量名称。
答案 1 :(得分:0)
在您编写的第一个游标中
for %%t in (E:\test\test.txt) do (
ren "%%~ft" "%%~nxt.txt"
findstr /v /r /c:"^[ Deactivate: yes]*$" "%%~ft.txt" > "%%~ft"
)
我认为您应该将变量重命名为其他名称