INNER在UPDATE OUTPUT中加入一个t-sql查询
发布时间:2020-12-12 06:23:37 所属栏目:MsSql教程 来源:网络整理
导读:需要INNER加入UPDATE OUTPUT与另一个表返回的结果集并返回结果.可能吗? 这是一个小例子: CREATE TABLE [dbo].[Customers]( [CustomerId] [int],[CustomerName] [nvarchar](50))GOCREATE TABLE [dbo].[Orders]( [OrderId] [int],[OrderName] [nvarchar](50))
需要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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |