Въпреки че мисля, че JOIN
критерии е много малко вероятно, изглежда, че се опитвате да направите това?
РЕДАКТИРАНЕ:Промених JOIN
критерии, но това е, което търсите.Grouping By
колони, които са OR
'd е странно.
;WITH MinOrderDates AS
(
SELECT CustID
,OrderDate = MIN(OrderDate)
FROM Orders
GROUP BY CustID
)
UPDATE C
SET FirstOrderDate = MIN(O.OrderDate)
FROM Customers C
JOIN MinOrderDates O ON C.Id = O.CustID
Ето как ще изглежда вашата заявка с OR
s
;WITH MinOrderDates AS
(
SELECT ShipperId
,PickupId
,ConsigneeId
,DeliveryId
.BillingId
,OrderDate = MIN(OrderDate)
FROM Orders
GROUP BY ShipperId
,PickupId
,ConsigneeId
,DeliveryId
.BillingId
)
UPDATE C
SET FirstOrderDate = MIN(O.OrderDate)
FROM Customers C
JOIN MinOrderDates O ON o.ShipperId = C.Id or
o.PickupId = C.Id or
o.ConsigneeId = C.Id or
o.DeliveryId = C.Id or
o.BillingId = C.Id
РЕДАКТИРАНЕ:Въпреки че ми е трудно да намеря грешка в публикувания от вас синтаксис.