首页 > 代码库 > 关于update_set_from_where
关于update_set_from_where
下面这样的一个例子:
1 UPDATE psto SET productMaterialKind=sop.productMaterialKind 2 FROM #tempSale t 3 JOIN dbo.produceSaleTaskOrderDetail AS pstod ON t.saleOrderID=pstod.saleOrderID 4 JOIN dbo.produceSaleTaskOrder AS psto ON pstod.taskorderID = psto.taskOrderID 5 JOIN dbo.saleOrder AS so ON t.saleOrderID=so.saleOrderID 6 JOIN dbo.saleOrderDzProduct AS sop ON pstod.saleOrderID=sop.saleOrderID
update set from 语句格式
当where和set都需要关联一个表进行查询时,整个 update执行时,就需要对被关联的表进行两次扫描,显然效率比较低。
对于这种情况,Sybase和SQL SERVER的解决办法是使用UPDATE...SET...FROM...WHERE...的语法,实际上就是从源表获取更新数据。
在 SQL 中,表连接(left join、right join、inner join 等)常常用于 select 语句,其实在 SQL 语法中,这些连接也是可以用于update 和 delete 语句的,在这些语句中使用 join 还常常得到事半功倍的效果。
Update T_OrderForm SET T_OrderForm.SellerID =B.L_TUserID
FROM T_OrderForm A LEFT JOIN T_ProductInfo B ON B.L_ID=A.ProductID
用来同步两个表的数据!
关于update_set_from_where
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。