需要INNER加入UPDATE OUTPUT与另一个表返回的结果集并返回结果.可能吗?
这是一个小例子:
CREATE TABLE [dbo].[Customers] ( [CustomerId] [int],[CustomerName] [nvarchar](50) ) GO CREATE TABLE [dbo].[Orders] ( [OrderId] [int],[OrderName] [nvarchar](50) ) GO CREATE TABLE [dbo].[CustomerOrders] ( [CustomerId] [int],[OrderId] [int] ) GO INSERT INTO CustomerOrders (CustomerId,OrderId) VALUES (1,1) INSERT INTO CustomerOrders (CustomerId,2) INSERT INTO CustomerOrders (CustomerId,OrderId) VALUES (2,1) GO
需要更新CustomerOrders表上的OrderId并返回客户的名称,全部为1次.到目前为止,我只能返回CustomerIds:
UPDATE CustomerOrders SET OrderId=NULL OUTPUT Deleted.CustomerId WHERE OrderId='1'
解决方法
Tsql / sql Server 2005支持UPDATE子句中的JOIN – 请参见
documentation:
UPDATE CUSTOMERORDERS SET orderid = NULL OUTPUT c.customername FROM CUSTOMERORDERS co JOIN CUSTOMERS c ON c.customerid = co.customerid
原文地址:https://www.jb51.cc/mssql/79151.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。