加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 数据库 > MsSql > 正文

INNER在UPDATE OUTPUT中加入一个t-sql查询

发布时间:2020-05-30 12:39:12 所属栏目:MsSql 来源:互联网
导读:需要INNER加入UPDATE OUTPUT与另一个表返回的结果集并返回结果.可能吗? 这是一个小例子: CREATE TABLE [dbo].[Customers]( [CustomerId] [int], [CustomerName] [nvarchar](50))GOCREATE TABLE [dbo].[Orders]( [OrderId]

需要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

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读