FAQ |
Kalender |
![]() |
#1 | ||
|
|||
Klarade millennium-buggen
|
Jag har en service som skall göra olika saker beroende vad det är för produkt i en databastabell "OrderItems".
Kanske går det inte att ta för givet att hela ordern har hanterats så därför skulle jag behöva göra en Stored Procedure som räknar ingående OrderItems till en Order och om lika många ingående OrderItems är satta till IsHandled = 1 så skall Shippingstatus ändras. Kod:
UPDATE Order Set ShippingStatus = 3 WHERE ShippingStatus = 1 AND ("där alla ingående artiklarna har IsHandled=1") Tack på förhand. |
||
![]() |
![]() |
![]() |
#2 | ||
|
|||
Klarade millennium-buggen
|
Så här blev det till slut.
Kod:
UPDATE [Order] SET ShippingStatus = 3 WHERE ID IN ( SELECT DISTINCT o.ID from [Order] o INNER JOIN [OrderItem] oi ON o.ID = oi.OrderID WHERE o.ShippingStatus = 1 GROUP BY o.ID HAVING MIN(CAST(oi.IsHandled as int)) = 1 ) ![]() |
||
![]() |
![]() |
Svara |
|
|