UPDATE使用两个表,Concatenation

jlr*_*lin 5 sql oracle sql-update

我有两个表涉及这个我需要创建的查询,我不确定如何连接这两个表以便更新.

我有一个ITEM和CONSUMER_ITEMS表.ITEM表具有针对每个项目和UPC代码的不同代码.我需要将一个字符串与ITEM.UPC_CODE连接到CONSUMER_ITEMS.NEW_ITEM_CODE,其中CONSUMER_ITEMS.ITEM_CODE =(ITEM.ITEM_CODES的特定列表)

我如何更新CONSUMER_ITEMS.NEW_ITEM_CODE字段?

它基本上等于'string'|| ITEM.UPC但是如何引用CONSUMER_ITEMS.ITEM_CODE等于要更新的​​ITEM_CODES列表中的特定ITEM_CODE.

Ton*_*ews 9

听起来像你想要的:

UPDATE consumer_items ci
SET    new_item_code = (SELECT 'string' || item.upc_code
                        FROM   item
                        WHERE  item.item_code = ci.item_code
                       )
WHERE  ci.item_code IN ('a','b','c');
Run Code Online (Sandbox Code Playgroud)

或者,假设表之间存在外键关系,而consumer_items具有主键,则应该可以:

UPDATE (SELECT ci.id, ci.new_item_code, item.upc_code
        FROM   consumer_items ci
               JOIN item ON item.item_code = ci.item_code
        WHERE  ci.item_code IN ('a','b','c')
       ) v
SET v.new_item_code = 'string' || v.upc_code
Run Code Online (Sandbox Code Playgroud)

编辑:添加WHERE子句