我需要在SQL Server中使用其“父”表中的数据更新此表,如下所示:

表:销售

id (int)
udid (int)
assid (int)

表:ud

id  (int)
assid  (int)

sale.assid包含更新ud.assid的正确值。

什么查询将执行此操作?我在考虑加入,但我不确定是否可能。


当前回答

最简单的方法是使用SQL2005中引入的公共表表达式(CTE)

with cte as
(select u.assid col1 ,s.assid col2 from ud u inner join sale s on u.id = s.udid)
update cte set col1=col2

其他回答

PostgreSQL:

CREATE TABLE ud (id integer, assid integer);
CREATE TABLE sales (id integer, udid integer, assid integer);

UPDATE ud
SET assid = sales.assid
FROM sales
WHERE sales.id = ud.id;

试试这个吧,我想这对你有用

update ud

set ud.assid = sale.assid

from ud 

Inner join sale on ud.id = sale.udid

where sale.udid is not null
UPDATE tblAppraisalBasicData
SET tblAppraisalBasicData.ISCbo=1
FROM tblAppraisalBasicData SI INNER JOIN  aaa_test RAN ON SI.EmpID = RAN.ID

对于使用MySQL 5.7的prestashop用户

UPDATE
    ps_stock_available sa
    INNER JOIN ps_shop s
        ON sa.id_shop = s.id_shop AND s.id_shop = 1
    INNER JOIN ps_order_detail od
        ON sa.id_product = od.product_id AND od.id_order = 22417
SET
    sa.physical_quantity = sa.quantity + sa.reserved_quantity

这是一个例子,但重点正如埃里克在这里所说https://stackoverflow.com/a/1293347/5864034

您需要在FIRST处添加UPDATE语句,其中包含要连接的所有表的完整地址,然后添加SET语句

使用JOIN多个表简化更新查询。

   UPDATE
        first_table ft
        JOIN second_table st ON st.some_id = ft.some_id
        JOIN third_table tt  ON tt.some_id = st.some_id
        .....
    SET
        ft.some_column = some_value
    WHERE ft.some_column = 123456 AND st.some_column = 123456

请注意,first_table、second_table、third_table和123456这样的some_column是演示表名、列名和id。用有效名称替换它们。