我必须更新一个由3个表的连接返回的值的字段。

例子:

select
    im.itemid
    ,im.sku as iSku
    ,gm.SKU as GSKU
    ,mm.ManufacturerId as ManuId
    ,mm.ManufacturerName
    ,im.mf_item_number
    ,mm.ManufacturerID
from 
    item_master im, group_master gm, Manufacturer_Master mm 
where
    im.mf_item_number like 'STA%'
    and im.sku=gm.sku
    and gm.ManufacturerID = mm.ManufacturerID
    and gm.manufacturerID=34

我想更新表item_master的mf_item_number字段值,使用在上述条件中连接的其他一些值。

如何在MS SQL Server中做到这一点?


当前回答

上面没有使用sql,这里有一个基于连接语句更新表的例子。

UPDATE p
SET    p.category = c.category
FROM   products p
       INNER JOIN prodductcatagories pg
            ON  p.productid = pg.productid
       INNER JOIN categories c
            ON  pg.categoryid = c.cateogryid
WHERE  c.categories LIKE 'whole%'

其他回答

将其应用到MySQL中——UPDATE中没有FROM子句,但这是可行的:

UPDATE
    item_master im
    JOIN
    group_master gm ON im.sku=gm.sku 
    JOIN
    Manufacturer_Master mm ON gm.ManufacturerID=mm.ManufacturerID
SET
    im.mf_item_number = gm.SKU --etc
WHERE
    im.mf_item_number like 'STA%'
    AND
    gm.manufacturerID=34

最简单的方法之一是使用公共表表达式(因为你已经在SQL 2005上了):

with cte as (
select
    im.itemid
    ,im.sku as iSku
    ,gm.SKU as GSKU
    ,mm.ManufacturerId as ManuId
    ,mm.ManufacturerName
    ,im.mf_item_number
    ,mm.ManufacturerID
    , <your other field>
from 
    item_master im, group_master gm, Manufacturer_Master mm 
where
    im.mf_item_number like 'STA%'
    and im.sku=gm.sku
    and gm.ManufacturerID = mm.ManufacturerID
    and gm.manufacturerID=34)
update cte set mf_item_number = <your other field>

查询执行引擎将自行确定如何更新记录。

我一直在尝试做这样的事情,我刚刚想到尝试使用以下语法(使用元组)

update dstTable T
set (T.field1, T.field2, T.field3) = 
       (select S.value1, S.value2, S.value3
        from srcTable S
         where S.key = T.Key);

令人惊讶的是,它奏效了。我用的是甲骨文(我想是12c)。这是标准SQL或Oracle专用的吗?

注意:在我的例子中,我正在更新整个表(填充新列)。更新没有where子句,因此将更新所有行。当子查询不返回行时,字段将被设置为NULL。(并且它不能返回多于一行)。

让我给所有现有的答案加上一个警告:

当使用SELECT…FROM语法,您应该记住它是T-SQL的专有语法,并且是非确定性的。最糟糕的是,你没有得到警告或错误,它只是顺利地执行。

完整的解释和示例在文档中:

在指定FROM子句为更新操作提供条件时,请谨慎使用。UPDATE语句的结果是未定义的,如果该语句包含一个FROM子句,而该子句没有指定为每个被更新的列只有一个值可用,也就是说UPDATE语句不是确定的。

在SQL中使用连接查询进行更新是非常简单的,你可以不使用FROM子句进行更新。这里有一个例子:

    UPDATE customer_table c 

      JOIN  
          employee_table e
          ON c.city_id = e.city_id  
      JOIN 
          anyother_ table a
          ON a.someID = e.someID

    SET c.active = "Yes"

    WHERE c.city = "New york";