update 批量修改,oracle多表关联修改

UPDATE UNIT U SET U.BASED_LOT_RRN = (SELECT L.BASED_LOT_RRN FROM LOT L WHERE U.LOT_RRN = L.lot_rrn)

Oracle,多表关联update,需要EXISTS
update UNIT_SP_TEST_PROG G set file_column = ‘VFBC’
where EXISTS (SELECT 1 from UNIT_SP_DATA A where A.TEST_PROGRAM_RRN=G.TEST_PROGRAM_RRN AND file_column = ‘VFBC(5.00mA)’ and A.unit_rrn in
(SELECT unit_rrn FROM unit where lot_rrn = 52232377))

update process_workflow_lot P  set (P.ATTRIBUTE_DATA1,P.ATTRIBUTE_DATA2) =(
SELECT to_char(G.trans_end_timestamp,'yyyy-mm-dd hh24:mi:ss'),G.TRANS_PERFORMED_BY
FROM 
LOT_TRANS_HISTORY H,
transaction_log G,
LOT_STEP_HISTORY SH 
WHERE  h.trans_rrn = g.trans_rrn 
AND SH.STEP_SEQUENCE = H.STEP_SEQUENCE  
AND SH.lot_rrn = H.lot_rrn
AND P.lot_rrn = SH.lot_rrn
AND P.product_rrn = SH.PRODUCT_RRN
AND P.PROCESS_RRN = SH.PROCESS_RRN  
AND P.PROCESS_VERSION = SH.PROCESS_VERSION
--AND to_char(P.ROUTE_RRN) = SUBSTR(SH.PROCESS_STEP_VERSION, instr(SH.PROCESS_STEP_VERSION,'|')+1,instr(SH.PROCESS_STEP_VERSION,',',instr(SH.PROCESS_STEP_VERSION,'|'))-instr(SH.PROCESS_STEP_VERSION,'|')-1) -- 工序
AND instr(SH.PROCESS_STEP_VERSION, P.ROUTE_RRN || ',' || P.ROUTE_VERSION )>1 --工序相等,NAMED_OBJECT中instacne_rrn是主键,不必担心重复
AND P.OPERATION_RRN = SH.OPERATION_RRN 
AND P.route_process_seq = SH.ROUTE_SEQ
AND P.OPERATION_ROUTE_SEQ = SH.OPERATION_SEQ
AND g.trans_id = 'MOVEIN'
)
where  P.lot_rrn = 5177911
### Oracle关联更新 `UPDATE` 语法示例 在 Oracle 数据库中,可以通过种方式实现基于两关联的更新操作。以下是几种常见的方法及其具体语法: #### 方法一:使用子查询的方式 这种方法通过在 `SET` 子句中嵌套子查询来完成更新操作。需要注意的是,在子查询中可以利用另一张的数据作为更新依据。 ```sql UPDATE table_a A SET A.column_to_update = ( SELECT B.update_value_column FROM table_b B WHERE A.join_key = B.join_key ) WHERE EXISTS ( SELECT 1 FROM table_b B WHERE A.join_key = B.join_key ); ``` 此方法适用于目标列仅需从单个匹配记录获取值的情况[^2]。 --- #### 方法二:使用 `MERGE` 语句 `MERGE` 是 Oracle 提供的一种高效机制,用于在同一 SQL 语句中处理插入和更新逻辑。对于只涉及更新的操作,也可以简化为以下形式: ```sql MERGE INTO table_a A USING table_b B ON (A.join_key = B.join_key) WHEN MATCHED THEN UPDATE SET A.column_to_update = B.update_value_column; ``` 该方法的优势在于其清晰性和性能优化能力,尤其适合大规模数据集的批量更新场景[^1]。 --- #### 方法三:创建临时视图并更新 如果业务逻辑较为复杂或者需要次重复调用相同的联接条件,则可先定义一个视图再对其进行修改。不过这种方式要求被更改的目标字段所属格必须显式指定于最终的 `WHERE` 条件之中以防误改其他无关行项。 ```sql CREATE OR REPLACE VIEW temp_view AS SELECT A.*, B.update_value_column FROM table_a A JOIN table_b B ON A.join_key = B.join_key; -- 执行实际更新动作前记得删除原有视图对象以免冲突 DROP TABLE IF EXISTS updated_table CASCADE CONSTRAINTS; INSERT INTO updated_table(column_list,...) SELECT column_list,... FROM temp_view V; COMMIT; ``` 尽管如此,通常建议直接采用前述两种更为简洁明了的形式除非特殊需求确实存在必要性去构建额外层次结构[^3]。 --- ### 注意事项 - 当运用上述任意一种技术手段实施跨个关系型实体间同步调整数值时,请务必确认源端所提供参照信息具备唯一性特征以避免意外覆盖合法现有条目。 - 如果涉及到远程数据库链接情况下的联合运算符应用实例,请参阅关于如何配置外部连接字符串的相关指导文档[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值