Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- SELECT ROW_NUMBER() OVER (ORDER BY CONTAINER_ID) AS RowNumber, COUNT(*) OVER () AS TotalRows, ORDER_ID, CUSTOMER_ID, NAME, ADDRESS1, ADDRESS2, TOWN, POSTCODE, COUNTRY
- , CONTACT_PHONE, DELIVER_BY_DATE, DOCUMENTATION_TEXT_2, DOCUMENTATION_TEXT_3, ORDER_REFERENCE
- , TO_LOC_ID, CARRIER_ID, CONTAINER_ID, LOCATION_ID, cNAME, cADDRESS1, cADDRESS2
- , cPOSTCODE, cTOWN, cCOUNTRY, MAX(SKU_ID) AS SKU_ID, MAX(DESCRIPTION) AS DESCRIPTION, MAX(EAN_PARCEL) AS EAN_PARCEL
- , SUM(QTY_ON_HAND) AS QTY_ON_HAND, MAX(ExpiryDate) AS ExpiryDate, MAX(ExpiryDateEAN) AS ExpiryDateEAN, COUNT(SKU_ID) AS CountSkuID FROM (SELECT oh.ORDER_ID, oh.CUSTOMER_ID, oh.NAME, oh.ADDRESS1, oh.ADDRESS2, oh.TOWN, oh.POSTCODE, oh.COUNTRY
- , oh.CONTACT_PHONE, oh.DELIVER_BY_DATE, oh.DOCUMENTATION_TEXT_2, oh.DOCUMENTATION_TEXT_3, oh.ORDER_REFERENCE
- , oh.TO_LOC_ID, oh.CARRIER_ID, il.CONTAINER_ID, il.LOCATION_ID,c.NAME AS cNAME, c.ADDRESS1 AS cADDRESS1, c.ADDRESS2 AS cADDRESS2
- , c.ZipCode AS cPOSTCODE, c.TOWN AS cTOWN, c.COUNTRY AS cCOUNTRY, il.SKU_ID, s.DESCRIPTION, s.EAN_PARCEL
- , SUM(il.QTY_ON_HAND) AS QTY_ON_HAND, SUBSTRING((SELECT ',' + CONVERT(nvarchar(10),EXPIRY_DATE,103)
- + ' (' + CONVERT(nvarchar(8),SUM(QTY_ON_HAND)) + ') '
- FROM INVENTORY i WHERE i.CONTAINER_ID =il.CONTAINER_ID
- GROUP BY CONVERT(nvarchar(10),EXPIRY_DATE,103) FOR XML Path('')),2,8000)
- AS ExpiryDate, CASE WHEN ISNULL(MIN(il.EXPIRY_DATE),'')='' THEN '' ELSE CONVERT(NCHAR(6),MIN(il.EXPIRY_DATE), 12) END AS ExpiryDateEAN
- FROM CLIENT c, SKU s, ORDER_HEADER oh INNER JOIN INVENTORY il ON oh.ORDER_ID=il.ORDER_ID AND oh.CLIENT_ID=il.CLIENT_ID
- LEFT JOIN CUSTOMER_SKU cs ON il.CLIENT_ID=cs.CLIENT_ID AND il.SKU_ID=cs.SKU_ID AND oh.CUSTOMER_ID=cs.CUSTOMER_ID
- WHERE oh.CLIENT_ID = c.CLIENT_ID AND oh.ORDER_ID='8952282917' AND il.SKU_ID = s.SKU_ID AND il.CLIENT_ID = s.CLIENT_ID
- AND CASE WHEN oh.REPACK=1 AND cs.SKU_ID=il.SKU_ID
- THEN LEN(il.CONTAINER_ID)
- ELSE
- CASE WHEN il.FROM_TAG_ID<>il.CONTAINER_ID
- THEN LEN(il.CONTAINER_ID)
- ELSE 0
- END
- END
- =18
- AND CASE WHEN oh.REPACK=1 THEN
- CASE WHEN oh.STATUS_ID IN ('Repack', 'Complete') THEN 1 ELSE 0 END
- ELSE
- CASE WHEN oh.STATUS_ID IN ('Shortage', 'Picked', 'Complete') THEN 1 ELSE 0 END
- END = 1
- GROUP BY oh.ORDER_ID, oh.CUSTOMER_ID, oh.NAME, oh.ADDRESS1, oh.ADDRESS2, oh.TOWN, oh.POSTCODE, oh.COUNTRY, oh.CONTACT_PHONE, oh.DELIVER_BY_DATE, oh.DOCUMENTATION_TEXT_2, oh.DOCUMENTATION_TEXT_3, oh.ORDER_REFERENCE, oh.TO_LOC_ID, oh.CARRIER_ID, il.CONTAINER_ID, il.LOCATION_ID, c.NAME, c.ADDRESS1, c.ADDRESS2, c.ZipCode, c.TOWN, c.COUNTRY, il.SKU_ID, s.DESCRIPTION, s.EAN_PARCEL
- UNION ALL
- SELECT oh.ORDER_ID, oh.CUSTOMER_ID, oh.NAME, oh.ADDRESS1, oh.ADDRESS2, oh.TOWN, oh.POSTCODE, oh.COUNTRY
- , oh.CONTACT_PHONE, oh.DELIVER_BY_DATE, oh.DOCUMENTATION_TEXT_2, oh.DOCUMENTATION_TEXT_3, oh.ORDER_REFERENCE
- , oh.TO_LOC_ID, oh.CARRIER_ID, il.CONTAINER_ID, il.LOCATION_ID, c.NAME AS cNAME, c.ADDRESS1 AS cADDRESS1, c.ADDRESS2 AS cADDRESS2
- , c.ZipCode AS cPOSTCODE, c.TOWN AS cTOWN, c.COUNTRY AS cCOUNTRY, '' AS SKU_ID, '' AS DESCRIPTION, '' AS EAN_PARCEL
- , SUM(il.QTY_ON_HAND) AS QTY_ON_HAND, CONVERT(nvarchar(10), MIN(il.EXPIRY_DATE), 103) AS ExpiryDate
- , CASE WHEN ISNULL(MIN(il.EXPIRY_DATE),'')='' THEN '' ELSE CONVERT(NCHAR(6),MIN(il.EXPIRY_DATE), 12) END AS ExpiryDateEAN
- FROM CLIENT c, SKU s, ORDER_HEADER oh INNER JOIN INVENTORY il ON oh.ORDER_ID=il.ORDER_ID AND oh.CLIENT_ID=il.CLIENT_ID
- LEFT JOIN CUSTOMER_SKU cs ON il.CLIENT_ID=cs.CLIENT_ID AND il.SKU_ID=cs.SKU_ID AND oh.CUSTOMER_ID=cs.CUSTOMER_ID
- WHERE oh.CLIENT_ID = c.CLIENT_ID AND oh.ORDER_ID='8952282917' AND il.SKU_ID = s.SKU_ID AND il.CLIENT_ID = s.CLIENT_ID
- AND CASE WHEN oh.REPACK=1 AND cs.SKU_ID=il.SKU_ID
- THEN LEN(il.CONTAINER_ID)
- ELSE
- CASE WHEN il.FROM_TAG_ID<>il.CONTAINER_ID
- THEN LEN(il.CONTAINER_ID)
- ELSE 0
- END
- END
- <>18
- AND CASE WHEN oh.REPACK=1 THEN
- CASE WHEN oh.STATUS_ID IN ('Repack', 'Complete') THEN 1 ELSE 0 END
- ELSE
- CASE WHEN oh.STATUS_ID IN ('Shortage', 'Picked', 'Complete') THEN 1 ELSE 0 END
- END = 1
- GROUP BY oh.ORDER_ID, oh.CUSTOMER_ID, oh.NAME, oh.ADDRESS1, oh.ADDRESS2, oh.TOWN, oh.POSTCODE, oh.COUNTRY, oh.CONTACT_PHONE, oh.DELIVER_BY_DATE, oh.DOCUMENTATION_TEXT_2, oh.DOCUMENTATION_TEXT_3, oh.ORDER_REFERENCE, oh.TO_LOC_ID, oh.CARRIER_ID, il.CONTAINER_ID, il.LOCATION_ID, c.NAME, c.ADDRESS1, c.ADDRESS2, c.ZipCode, c.TOWN, c.COUNTRY) label
- WHERE CASE WHEN LEN(ISNULL(SKU_ID,''))=0 THEN 14 ELSE LEN(ISNULL(EAN_PARCEL,'')) END = 14
- GROUP BY ORDER_ID, CUSTOMER_ID, NAME, ADDRESS1, ADDRESS2, TOWN, POSTCODE, COUNTRY
- , CONTACT_PHONE, DELIVER_BY_DATE, DOCUMENTATION_TEXT_2, DOCUMENTATION_TEXT_3, ORDER_REFERENCE
- , TO_LOC_ID, CARRIER_ID, CONTAINER_ID, LOCATION_ID, cNAME, cADDRESS1, cADDRESS2
- , cPOSTCODE, cTOWN, cCOUNTRY
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement