吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1084|回复: 15
收起左侧

[求助] SQL游标

[复制链接]
yk156511 发表于 2022-3-18 11:22
同一个字段A,批量修改所涉及到的表。
现在有一个字段A  A=13 想在的需求是把所有涉及到字段A的表13改为另一个值
单表修改是 update table set A=X where A=13
现在写循环 来把所有A字段的表值修改 要怎么写啊。

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

夏汉森 发表于 2022-3-18 11:41
select t.table_name from user_tab_columns t where column_name = 'A'
把查询结果放进游标里
 楼主| yk156511 发表于 2022-3-18 11:47
夏汉森 发表于 2022-3-18 11:41
select t.table_name from user_tab_columns t where column_name = 'A'
把查询结果放进游标里

declare
  v_s          varchar2(2000);
  v_table_name varchar(100);
  cursor c1 is
    select distinct m_table from oa2_mapped where m_field = 'FWXZ';
begin
  open c1;
  loop
    fetch c1
      into v_table_name;
    exit when c1%notfound;
请问下面的update 应该怎么写呢。
夏汉森 发表于 2022-3-18 11:51
v_s := 'update ' || v_table_name  || ' set A=X where A=13 ' ;
execute immediate v_s;
夏汉森 发表于 2022-3-18 11:52
yk156511 发表于 2022-3-18 11:47
declare
  v_s          varchar2(2000);
  v_table_name varchar(100);

看4楼内容
 楼主| yk156511 发表于 2022-3-18 12:28

哪里的问题啊
QZL$CY%V_NMN5$%X]4ER9CX.png
夏汉森 发表于 2022-3-18 13:49

你 fwxz 列不是数值类型吧
 楼主| yk156511 发表于 2022-3-18 13:59
夏汉森 发表于 2022-3-18 13:49
你 fwxz 列不是数值类型吧

image.png
夏汉森 发表于 2022-3-18 14:32

v_s := 'update ' || v_table_name  || ' set A=X where A= ' ||  '''' || 13 || '''' ;

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
yk156511 + 1 + 1 谢谢@Thanks!

查看全部评分

 楼主| yk156511 发表于 2022-3-18 14:41

可以执行了,另外请教下。为什么要加这个来执行啊。 只在拼接中用到过这个。谢谢啦。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 14:34

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表