Subversion Repositories SmartDukaan

Rev

Rev 12844 | Rev 13090 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
4500 mandeep.dh 1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
3
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
4
 
5
<mapper namespace="in.shop2020.warehouse.persistence.ScanMapper">
6
  <resultMap type="scan" id="scanResult">
7
    <id property="id" column="id"/>
8
  </resultMap>
9
 
10
  <insert id="insert" parameterType="scan" useGeneratedKeys="true" keyProperty="id">
11
    INSERT INTO scanNew
7410 amar.kumar 12
      (inventoryItemId, warehouseId, type, scannedAt, quantity, orderId, transferLotId, remarks)
4500 mandeep.dh 13
    VALUES
7410 amar.kumar 14
      (#{inventoryItemId}, #{warehouseId}, #{type}, NOW(), #{quantity}, #{orderId}, #{transferLotId}, #{remarks})
4500 mandeep.dh 15
  </insert>
16
 
17
  <select id="get" parameterType="map" resultType="scan">
18
    SELECT * 
19
    FROM scanNew
20
    WHERE inventoryItemId = #{inventoryItemId}
21
    <if test="scanType != null">
22
        AND type = #{scanType}
23
    </if>
24
    ORDER BY scannedAt
25
  </select>
5361 mandeep.dh 26
 
27
  <select id="getScansFromOrderId" parameterType="java.lang.Long" resultType="scan">
28
    SELECT * 
29
    FROM scanNew
30
    WHERE orderId = #{orderId}
31
    ORDER BY scannedAt
32
  </select>
5372 mandeep.dh 33
 
7199 amar.kumar 34
  <select id="getScansForOrderAndItem" parameterType="map" resultType="scan">
35
    SELECT  s.id as id, s.inventoryItemId as inventoryItemId, s.warehouseId as warehouseId, s.type as type, 
36
    	s.scannedAt as scannedAt, s.quantity as quantity, s.orderId as orderId
37
    FROM scanNew s
38
    JOIN inventoryItem i
39
    	ON (s.inventoryItemId = i.id)
40
    WHERE i.itemId = #{itemId}
41
    AND s.orderId = #{orderId}
42
    ORDER BY scannedAt
43
  </select>  
44
 
45
 
5372 mandeep.dh 46
  <select id="getPurchaseScans" parameterType="map" resultType="detailedPurchaseScan">
5395 mandeep.dh 47
    SELECT p.purchaseOrder_id AS purchaseOrderId, 1000 * UNIX_TIMESTAMP(po.createdAt) AS poCreatedAt, s.name AS supplierName,
6494 amar.kumar 48
        GROUP_CONCAT(DISTINCT(p.invoiceNumber)) AS invoiceNumbers, GROUP_CONCAT(DISTINCT(inv.receivedFrom)) AS receivedBy, i.itemId,
8580 amar.kumar 49
        brand, modelName, modelNumber, color, unitPrice, SUM(initialQuantity) AS quantity, 1000 * UNIX_TIMESTAMP(receivedOn) as purchasedAt, 
50
        p.id as purchaseId, nlc, po.warehouseId 
5372 mandeep.dh 51
    FROM purchase p
52
    JOIN purchaseorder po 
53
        ON (po.id = p.purchaseOrder_id)
54
    JOIN inventoryItem i
55
        ON (p.id = i.purchaseId)
56
    JOIN lineitem l
57
        ON (l.itemId = i.itemId AND l.purchaseOrder_id = po.id)
58
    JOIN supplier s
59
        ON (s.id = po.supplierId)
6494 amar.kumar 60
    JOIN invoice inv
7453 amar.kumar 61
    	ON (inv.invoiceNumber = p.invoiceNumber AND inv.supplierId = po.supplierId) 
5372 mandeep.dh 62
    WHERE po.createdAt BETWEEN #{startDate} AND #{endDate} 
6364 rajveer 63
    AND lastScanType != 'DOA_REPLACED' 
6362 rajveer 64
    GROUP BY p.purchaseOrder_id, p.id, i.itemId
65
    ORDER BY p.purchaseOrder_id, p.id, i.itemId
5372 mandeep.dh 66
  </select>
5496 mandeep.dh 67
 
7210 amar.kumar 68
  <select id="getPurchaseScansByGrnDate" parameterType="map" resultType="detailedPurchaseScan">
69
    SELECT p.purchaseOrder_id AS purchaseOrderId, 1000 * UNIX_TIMESTAMP(po.createdAt) AS poCreatedAt, s.name AS supplierName,
70
        p.invoiceNumber AS invoiceNumbers, inv.receivedFrom AS receivedBy, i.itemId,brand, modelName, modelNumber, color, 
8580 amar.kumar 71
        unitPrice, SUM(initialQuantity) AS quantity, 1000 * UNIX_TIMESTAMP(receivedOn) as purchasedAt, p.id as purchaseId, 
12800 manish.sha 72
        nlc, po.warehouseId, po.taxType, 1000 * UNIX_TIMESTAMP(inv.invoiceDate) as invoiceDate, p.purchaseComments 
7210 amar.kumar 73
    FROM purchase p
74
    JOIN purchaseorder po 
75
        ON (po.id = p.purchaseOrder_id)
76
    JOIN inventoryItem i
77
        ON (p.id = i.purchaseId)
78
    JOIN lineitem l
79
        ON (l.itemId = i.itemId AND l.purchaseOrder_id = po.id)
80
    JOIN supplier s
81
        ON (s.id = po.supplierId)
82
    JOIN invoice inv
7224 amar.kumar 83
    	ON (inv.invoiceNumber = p.invoiceNumber AND inv.supplierId = po.supplierId)
7216 amar.kumar 84
    WHERE p.receivedOn BETWEEN #{startDate} AND #{endDate}
85
    AND inv.date  &lt; #{endDate}
12357 manish.sha 86
    AND inv.date  &gt;= ADDDATE(#{startDate},-1)
7210 amar.kumar 87
    AND lastScanType != 'DOA_REPLACED' 
7224 amar.kumar 88
    GROUP BY p.purchaseOrder_id, p.id, i.itemId
89
    ORDER BY p.purchaseOrder_id, p.id, i.itemId
7210 amar.kumar 90
  </select>
91
 
5496 mandeep.dh 92
  <select id="fetchMismatchScansPerInvoiceNumber" parameterType="java.util.Date" resultType="invoiceScan" >
93
    SELECT i.invoiceNumber, i.numItems, sum(initialQuantity) as scannedQuantity, i.date, s.name as supplierName
94
    FROM invoice i
95
    JOIN supplier s
7090 amar.kumar 96
    	ON (i.supplierId = s.id)
5496 mandeep.dh 97
    LEFT JOIN purchase p
98
        ON (p.invoiceNumber = i.invoiceNumber)
7089 amar.kumar 99
    LEFT JOIN inventoryItem ii 
100
    	ON (ii.purchaseId = p.id)
101
    JOIN scanNew sn
102
    	ON (sn.inventoryItemId = ii.id)
5496 mandeep.dh 103
    WHERE i.date = #{date}
7089 amar.kumar 104
    AND	sn.scannedAt between #{date} and ADDDATE(#{date},1)
105
    AND sn.type = 'PURCHASE'
106
    AND s.id !=1
5496 mandeep.dh 107
    GROUP BY i.invoiceNumber, i.numItems
108
    HAVING SUM(initialQuantity) != i.numItems
109
  </select>
5372 mandeep.dh 110
 
5711 mandeep.dh 111
  <select id="getInventoryAge" resultType="inventoryAge">
112
    SELECT t.itemId, brand, modelName, modelNumber, color,
113
        SUM((age &lt; 1) * currentQuantity) AS freshCount, 
5768 mandeep.dh 114
        SUM((age &gt;= 1 and age &lt; 2) * currentQuantity) AS oneToTwoCount, 
115
        SUM((age &gt;= 2 and age &lt; 3) * currentQuantity) AS twoToThreeCount, 
116
        SUM((age &gt;= 3 and age &lt; 4) * currentQuantity) AS threeToFourCount, 
117
        SUM((age &gt;= 4) * currentQuantity) as fourPlusCount,
118
        SUM((age &gt;= 1) * currentQuantity) as onePlusCount,
8626 amar.kumar 119
        SUM((age &gt;= 13) * currentQuantity) as threeMonthPlusCount,
120
        SUM((age &gt;= 26) * currentQuantity) as sixMonthPlusCount,
12800 manish.sha 121
        SUM((age &gt;= 0 and age &lt;= 13) * currentQuantity) AS zeroToThreeMonthCount,
11512 manish.sha 122
        SUM((age &gt; 13 and age &lt;= 26) * currentQuantity) AS threeToSixMonthCount,
123
        SUM((age &gt; 26 and age &lt;= 52) * currentQuantity) AS sixToTwelveMonthCount,
11220 manish.sha 124
        SUM((age &gt; 52) * currentQuantity) AS twelveMonthsPlusCount,
9830 amar.kumar 125
        SUM((age &gt;= 1) * unitPrice*currentQuantity) as onePlusCost,
5768 mandeep.dh 126
        SUM(currentQuantity) as zeroPlusCount,
9830 amar.kumar 127
        SUM(l.unitPrice*currentQuantity) as zeroPlusCost,
5768 mandeep.dh 128
        l.productGroup as category
5711 mandeep.dh 129
    FROM  (SELECT ii.id, ii.itemId, ii.currentQuantity, ii.purchaseId,
7838 amar.kumar 130
                DATEDIFF(now(), MIN(s.scannedAt)) / 7 as age
5711 mandeep.dh 131
           FROM inventoryItem ii 
132
           JOIN scanNew s 
133
                ON (s.inventoryItemId = ii.id) 
8625 amar.kumar 134
           WHERE (ii.lastScanType IN ('PURCHASE', 'SALE_RET', 'MARKED_GOOD') 
135
           OR ii.currentQuantity>1)
12591 manish.sha 136
           AND ii.lastScanType != 'MARKED_BAD' 
8630 amar.kumar 137
           AND (transferStatus is NULL or transferStatus != 'IN_TRANSIT')
12357 manish.sha 138
           AND ii.physicalWarehouseId NOT IN (select id from inventory.warehouse where vendor_id= 40 
12543 manish.sha 139
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
5711 mandeep.dh 140
           GROUP BY ii.id, ii.itemId, ii.currentQuantity) t 
141
    JOIN purchase p 
142
        ON (p.id = t.purchaseId) 
143
    JOIN lineitem l 
144
        ON (l.purchaseOrder_id = p.purchaseOrder_id AND l.itemId = t.itemId)
145
    GROUP BY t.itemId 
146
    HAVING SUM(currentQuantity) != 0
147
  </select>
6322 amar.kumar 148
 
7089 amar.kumar 149
  <!--select id="inventoryAgeOnePlus" resultType="detailedInventoryAge">
150
    SELECT t.itemId, brand, modelName, modelNumber, color, scannedAt, i.warehouseId
151
        SUM((age &gt;= 1) * currentQuantity) AS onePlusCount, 
152
        SUM((age &gt;= 1) * unitPrice) as onePlusCost,
153
        l.productGroup as category
154
    FROM  (SELECT ii.id, ii.itemId, ii.currentQuantity, ii.purchaseId, MIN(s.scannedAt)
155
                DATEDIFF(now(), MAX(s.scannedAt)) / 7 as age
156
           FROM inventoryItem ii 
157
           JOIN scanNew s 
158
                ON (s.inventoryItemId = ii.id) 
159
           WHERE ii.lastScanType IN ('PURCHASE', 'SALE_RET') 
160
           GROUP BY ii.id, ii.itemId, ii.currentQuantity) t 
161
    JOIN purchase p 
162
        ON (p.id = t.purchaseId) 
163
    JOIN lineitem l 
164
        ON (l.purchaseOrder_id = p.purchaseOrder_id AND l.itemId = t.itemId)
165
    GROUP BY t.itemId, i.warehouseId 
166
    HAVING SUM(currentQuantity) != 0
167
  </select-->
168
 
169
 
170
 
6322 amar.kumar 171
  <select id = "getScansForItem" parameterType = "map" resultType = "scan">
172
	  SELECT s.id, s.inventoryItemId, s.warehouseId, s.type, s.scannedAt, 
173
	  s.quantity, s.orderId from scanNew s JOIN inventoryItem i 
174
	  ON 
175
	  s.inventoryItemId = i.id 
176
	  AND
6414 amar.kumar 177
	  i.itemId = #{itemId} 
6322 amar.kumar 178
	  AND
179
	  s.scannedAt BETWEEN #{fromDate} AND #{toDate};
180
  </select>
181
 
6558 amar.kumar 182
  <insert id="genericScan" parameterType="scan" useGeneratedKeys="true" keyProperty="id">
6467 amar.kumar 183
    INSERT INTO scanNew
7410 amar.kumar 184
     (inventoryItemId, warehouseId, type, scannedAt, quantity, orderId, transferLotId, remarks)
6467 amar.kumar 185
    VALUES
7410 amar.kumar 186
      (#{inventoryItemId}, #{warehouseId}, #{type}, NOW(), #{quantity}, #{orderId}, #{transferLotId}, #{remarks})
6467 amar.kumar 187
  </insert>
188
 
6558 amar.kumar 189
  <select id = "getCurrentSerializedInventoryByScans" resultType = "inventoryAvailability">
190
	SELECT x.itemId, ci.brand, ci.model_name as modelName, 
6630 amar.kumar 191
	ci.model_number as modelNumber, ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity
6558 amar.kumar 192
	from 
11750 manish.sha 193
	(select i.itemId, sum(quantity) as inx from scanNew s 
6558 amar.kumar 194
		JOIN inventoryItem i ON (i.id = s.inventoryItemId) 
195
		JOIN catalog.item c ON i.itemId = c.id 
10407 amar.kumar 196
		JOIN inventory.warehouse w ON w.id = s.warehouseId
197
		where s.type in ('PURCHASE','SALE_RET', 'MARKED_GOOD','WAREHOUSE_TRANSFER_IN') and c.type = 'SERIALIZED'
10402 manish.sha 198
		and w.billingWarehouseId = #{physicalWarehouseId} 
6558 amar.kumar 199
		group by i.itemId ) as x 
6630 amar.kumar 200
	LEFT JOIN 
11750 manish.sha 201
	(select i.itemId, sum(quantity) as outx from scanNew s 
6558 amar.kumar 202
		JOIN inventoryItem i on i.id = s.inventoryItemId 
203
		JOIN catalog.item c ON i.itemId = c.id 
10407 amar.kumar 204
		JOIN inventory.warehouse w ON w.id = s.warehouseId
7678 amar.kumar 205
		where s.type in ('SALE','LOST_IN_WAREHOUSE','PURCHASE_RETURN','MARKED_USED','MARKED_BAD','WAREHOUSE_TRANSFER_OUT') and c.type = 'SERIALIZED'
10407 amar.kumar 206
		and w.billingWarehouseId = #{physicalWarehouseId}
6558 amar.kumar 207
		group by i.itemId) as y 
208
	ON x.itemId = y.itemId 
209
	JOIN catalog.item ci ON ci.id = x.itemId 
6630 amar.kumar 210
	where ci.type = 'SERIALIZED' having quantity>0  
6558 amar.kumar 211
  </select>
6762 amar.kumar 212
 
213
<select id = "getHistoricSerializedInventoryByScans" resultType = "inventoryAvailability" parameterType = "date">
214
	SELECT x.itemId, ci.brand, ci.model_name as modelName, 
215
	ci.model_number as modelNumber, ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity
216
	from 
217
	(select i.itemId, count(*) as inx from scanNew s 
218
		JOIN inventoryItem i ON (i.id = s.inventoryItemId) 
219
		JOIN catalog.item c ON i.itemId = c.id 
7678 amar.kumar 220
		where s.type in ('PURCHASE','SALE_RET', 'MARKED_GOOD','WAREHOUSE_TRANSFER_IN') and c.type = 'SERIALIZED'
6762 amar.kumar 221
		and s.scannedAt &lt; #{date} 
222
		group by i.itemId ) as x 
223
	LEFT JOIN 
224
	(select i.itemId, count(*) as outx from scanNew s 
225
		JOIN inventoryItem i on i.id = s.inventoryItemId 
226
		JOIN catalog.item c ON i.itemId = c.id 
7678 amar.kumar 227
		where s.type in ('SALE','LOST_IN_WAREHOUSE','PURCHASE_RETURN','MARKED_USED','MARKED_BAD','WAREHOUSE_TRANSFER_OUT') and c.type = 'SERIALIZED'
6762 amar.kumar 228
		and s.scannedAt &lt; #{date} 
229
		group by i.itemId) as y 
230
	ON x.itemId = y.itemId 
231
	JOIN catalog.item ci ON ci.id = x.itemId 
232
	where ci.type = 'SERIALIZED' having quantity>0  
233
  </select>
234
 
10308 amar.kumar 235
<select id = "getOurHistoricSerializedInventoryByScans" resultType = "inventoryAvailability" parameterType = "date">
236
	SELECT x.itemId, ci.brand, ci.model_name as modelName, 
237
	ci.model_number as modelNumber, ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity
238
	from 
239
	(select i.itemId, count(*) as inx from scanNew s 
240
		JOIN inventoryItem i ON (i.id = s.inventoryItemId) 
241
		JOIN catalog.item c ON i.itemId = c.id 
242
		where s.type in ('PURCHASE','SALE_RET', 'MARKED_GOOD','WAREHOUSE_TRANSFER_IN') and c.type = 'SERIALIZED'
243
		and s.scannedAt &lt; #{date} 
12543 manish.sha 244
		and s.warehouseId not in (select id from inventory.warehouse where vendor_id= 40 
245
	    and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
10308 amar.kumar 246
		group by i.itemId ) as x 
247
	LEFT JOIN 
248
	(select i.itemId, count(*) as outx from scanNew s 
249
		JOIN inventoryItem i on i.id = s.inventoryItemId 
250
		JOIN catalog.item c ON i.itemId = c.id 
251
		where s.type in ('SALE','LOST_IN_WAREHOUSE','PURCHASE_RETURN','MARKED_USED','MARKED_BAD','WAREHOUSE_TRANSFER_OUT') and c.type = 'SERIALIZED'
252
		and s.scannedAt &lt; #{date}
12543 manish.sha 253
		and s.warehouseId not in (select id from inventory.warehouse where vendor_id= 40 
254
	    and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
10308 amar.kumar 255
		group by i.itemId) as y 
256
	ON x.itemId = y.itemId 
257
	JOIN catalog.item ci ON ci.id = x.itemId 
258
	where ci.type = 'SERIALIZED' having quantity>0  
259
</select>
260
 
6558 amar.kumar 261
 
6630 amar.kumar 262
  <select id = "getCurrentNonSerializedInventoryByScans" resultType = "inventoryAvailability">
263
	SELECT x.itemId, ci.brand, ci.model_name as modelName, 
264
	ci.model_number as modelNumber, ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity
265
	from 
266
	(select i.itemId, sum(quantity) as inx from scanNew s 
267
		JOIN inventoryItem i ON (i.id = s.inventoryItemId) 
268
		JOIN catalog.item c ON i.itemId = c.id 
8603 amar.kumar 269
		JOIN inventory.warehouse w ON w.id = s.warehouseId
7678 amar.kumar 270
		where s.type in ('PURCHASE','SALE_RET', 'MARKED_GOOD','WAREHOUSE_TRANSFER_IN') and c.type = 'NON_SERIALIZED'
8603 amar.kumar 271
		and w.billingWarehouseId = #{physicalWarehouseId}
6630 amar.kumar 272
		group by i.itemId ) as x 
273
	LEFT JOIN 
274
	(select i.itemId, sum(quantity) as outx from scanNew s 
275
		JOIN inventoryItem i on i.id = s.inventoryItemId 
276
		JOIN catalog.item c ON i.itemId = c.id 
8603 amar.kumar 277
		JOIN inventory.warehouse w ON w.id = s.warehouseId
7678 amar.kumar 278
		where s.type in ('SALE','LOST_IN_WAREHOUSE','PURCHASE_RETURN','MARKED_USED','MARKED_BAD','WAREHOUSE_TRANSFER_OUT') and c.type = 'NON_SERIALIZED'
8603 amar.kumar 279
		and w.billingWarehouseId = #{physicalWarehouseId}
6630 amar.kumar 280
		group by i.itemId) as y 
281
	ON x.itemId = y.itemId 
282
	JOIN catalog.item ci ON ci.id = x.itemId 
283
	where ci.type = 'NON_SERIALIZED' having quantity>0  
284
  </select>
6762 amar.kumar 285
 
286
<select id = "getHistoricNonSerializedInventoryByScans" resultType = "inventoryAvailability" parameterType = "date">
287
	SELECT x.itemId, ci.brand, ci.model_name as modelName, 
288
	ci.model_number as modelNumber, ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity
289
	from 
7410 amar.kumar 290
	(SELECT i.itemId, sum(quantity) as inx from scanNew s 
6762 amar.kumar 291
		JOIN inventoryItem i ON (i.id = s.inventoryItemId) 
292
		JOIN catalog.item c ON i.itemId = c.id 
7678 amar.kumar 293
		where s.type in ('PURCHASE','SALE_RET', 'MARKED_GOOD','WAREHOUSE_TRANSFER_IN') and c.type = 'NON_SERIALIZED' 
6762 amar.kumar 294
		and s.scannedAt &lt; #{date}
295
		group by i.itemId ) as x 
296
	LEFT JOIN 
7410 amar.kumar 297
	(SELECT i.itemId, sum(quantity) as outx from scanNew s 
6762 amar.kumar 298
		JOIN inventoryItem i on i.id = s.inventoryItemId 
299
		JOIN catalog.item c ON i.itemId = c.id 
7678 amar.kumar 300
		where s.type in ('SALE','LOST_IN_WAREHOUSE','PURCHASE_RETURN','MARKED_USED','MARKED_BAD','WAREHOUSE_TRANSFER_OUT') and c.type = 'NON_SERIALIZED'
6762 amar.kumar 301
		and s.scannedAt &lt; #{date} 
302
		group by i.itemId) as y 
303
	ON x.itemId = y.itemId 
304
	JOIN catalog.item ci ON ci.id = x.itemId 
305
	where ci.type = 'NON_SERIALIZED' having quantity>0  
306
  </select>
307
 
10308 amar.kumar 308
<select id = "getOurHistoricNonSerializedInventoryByScans" resultType = "inventoryAvailability" parameterType = "date">
309
	SELECT x.itemId, ci.brand, ci.model_name as modelName, 
310
	ci.model_number as modelNumber, ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity
311
	from 
312
	(SELECT i.itemId, sum(quantity) as inx from scanNew s 
313
		JOIN inventoryItem i ON (i.id = s.inventoryItemId) 
314
		JOIN catalog.item c ON i.itemId = c.id 
315
		where s.type in ('PURCHASE','SALE_RET', 'MARKED_GOOD','WAREHOUSE_TRANSFER_IN') and c.type = 'NON_SERIALIZED' 
316
		and s.scannedAt &lt; #{date}
12543 manish.sha 317
		and s.warehouseId not in (select id from inventory.warehouse where vendor_id= 40 
318
	    and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
10308 amar.kumar 319
		group by i.itemId ) as x 
320
	LEFT JOIN 
321
	(SELECT i.itemId, sum(quantity) as outx from scanNew s 
322
		JOIN inventoryItem i on i.id = s.inventoryItemId 
323
		JOIN catalog.item c ON i.itemId = c.id 
324
		where s.type in ('SALE','LOST_IN_WAREHOUSE','PURCHASE_RETURN','MARKED_USED','MARKED_BAD','WAREHOUSE_TRANSFER_OUT') and c.type = 'NON_SERIALIZED'
325
		and s.scannedAt &lt; #{date}
12543 manish.sha 326
		and s.warehouseId not in (select id from inventory.warehouse where vendor_id= 40 
327
	    and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
10308 amar.kumar 328
		group by i.itemId) as y 
329
	ON x.itemId = y.itemId 
330
	JOIN catalog.item ci ON ci.id = x.itemId 
331
	where ci.type = 'NON_SERIALIZED' having quantity>0  
332
</select>
333
 
6880 amar.kumar 334
 <select id = "getMovementSerializedInventoryByScans" resultType = "inventoryMovement" parameterType = "map">
7410 amar.kumar 335
 	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, count(*) as quantity 
6762 amar.kumar 336
 	FROM inventoryItem i JOIN scanNew s ON i.id = s.inventoryItemId 
337
 	LEFT JOIN catalog.item c ON i.itemId = c.id 
6963 amar.kumar 338
 	where s.scannedAt between #{startDate} and #{endDate} and c.type = 'SERIALIZED'
339
 	and i.currentWarehouseId not in (1,2,6,9) 
12357 manish.sha 340
 	and s.warehouseId not in (select id from inventory.warehouse where vendor_id= 40 
12543 manish.sha 341
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
6762 amar.kumar 342
 	group by itemId, s.type
343
 </select>
344
 
345
 <select id = "getMovementNonSerializedInventoryByScans" resultType = "inventoryMovement" parameterType = "map">
7410 amar.kumar 346
 	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, sum(quantity) as quantity 
6762 amar.kumar 347
 	FROM inventoryItem i JOIN scanNew s ON i.id = s.inventoryItemId 
348
 	LEFT JOIN catalog.item c ON i.itemId = c.id 
6963 amar.kumar 349
 	where s.scannedAt between #{startDate} and #{endDate} and c.type = 'NON_SERIALIZED'
10308 amar.kumar 350
 	and i.currentWarehouseId not in (1,2,6,9)
12357 manish.sha 351
 	and s.warehouseId not in (select id from inventory.warehouse where vendor_id= 40 
12543 manish.sha 352
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
6762 amar.kumar 353
 	group by itemId, s.type
6880 amar.kumar 354
 </select>
7216 amar.kumar 355
 
356
 <select id = "getCompleteMovementSerializedInventoryByScans" resultType = "inventoryMovement" parameterType = "map">
7410 amar.kumar 357
 	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, count(*) as quantity 
7216 amar.kumar 358
 	FROM inventoryItem i JOIN scanNew s ON i.id = s.inventoryItemId 
359
 	LEFT JOIN catalog.item c ON i.itemId = c.id 
13080 manish.sha 360
 	where s.scannedAt between #{startDate} and #{endDate} and c.type = 'SERIALIZED' 
7216 amar.kumar 361
 	group by itemId, s.type
362
 </select>
363
 
364
 <select id = "getCompleteMovementNonSerializedInventoryByScans" resultType = "inventoryMovement" parameterType = "map">
7410 amar.kumar 365
 	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, sum(quantity) as quantity 
7216 amar.kumar 366
 	FROM inventoryItem i JOIN scanNew s ON i.id = s.inventoryItemId 
367
 	LEFT JOIN catalog.item c ON i.itemId = c.id 
13080 manish.sha 368
 	where s.scannedAt between #{startDate} and #{endDate} and c.type = 'NON_SERIALIZED'  
7216 amar.kumar 369
 	group by itemId, s.type
370
 </select>
6630 amar.kumar 371
 
7410 amar.kumar 372
<select id = "getTransferrableWarehousesFromWarehouse" resultType = "java.lang.Long" parameterType = "java.lang.Long">
373
 	SELECT toWarehouseId  
374
 	FROM possibleWarehouseMovement  
375
 	WHERE fromWarehouseId = #{warehouseId}
376
 </select>
377
 
7957 amar.kumar 378
<select id = "getHistoricBadInventoryByScans" resultType = "inventoryAvailability" parameterType = "date">
379
	SELECT x.itemId, ci.brand, ci.model_name as modelName, ci.model_number as modelNumber, 
380
	ci.color as color, (x.inx-if(y.outx is null,0,y.outx)) as quantity 
381
	FROM 
382
		(SELECT i.itemId, count(*) as inx FROM scanNew s JOIN inventoryItem i ON 
383
		(i.id = s.inventoryItemId) JOIN catalog.item c ON i.itemId = c.id 
10407 amar.kumar 384
		where s.type in ('DOA_IN', 'SALE_RET_UNUSABLE') and 
10489 amar.kumar 385
		s.scannedAt &lt; #{date} and s.scannedAt &gt; '2013-01-01' group by i.itemId ) as x 
7957 amar.kumar 386
		LEFT JOIN 
387
		(SELECT i.itemId, count(*) as outx FROM scanNew s JOIN inventoryItem i ON
388
		i.id = s.inventoryItemId JOIN catalog.item c ON i.itemId = c.id WHERE 
10489 amar.kumar 389
		s.type in ('DOA_OUT') and s.scannedAt &lt; #{date} and s.scannedAt &gt; '2013-01-01' 
390
		group by i.itemId) as y 
7957 amar.kumar 391
		ON x.itemId = y.itemId 
392
		JOIN catalog.item ci ON ci.id = x.itemId 
393
	having quantity>0;
394
</select>
7410 amar.kumar 395
 
396
<select id = "getScansForTransferLot" resultType = "scan" parameterType = "java.lang.Long">
397
	SELECT * 
398
	FROM scanNew
399
	WHERE transferLotId = #{id}
400
	AND type = 'WAREHOUSE_TRANSFER_OUT'
401
</select>
10120 manish.sha 402
 
403
<select id= "getScansForTransferLotAndInventoryItem" resultType = "scan" parameterType="map" >
404
	SELECT * 
405
	FROM scanNew
406
	WHERE transferLotId = #{transferLotId}
407
	AND inventoryItemId = #{inventoryItemId}
408
	AND type = 'WAREHOUSE_TRANSFER_OUT'
409
	LIMIT 1
410
</select>
10689 manish.sha 411
 
412
<select id="getAmazonTransferredSkuDetails" resultType= "amazonTransferredSkuDetail" parameterType="map">
12357 manish.sha 413
	SELECT Z.itemId, Z.purchaseId, Z.purchaseDate, sum(Z.quantity) as quantity, Z.unitPrice, Z.nlc, 
414
	Z.brand, Z.modelName, Z.modelNumber, Z.category, Z.color, Z.taxType  
415
	FROM  (SELECT X.itemId, X.purchaseId, X.purchaseDate, X.quantity, X.unitPrice, X.nlc, X.brand, 
416
	X.modelName, X.modelNumber, X.category, X.color , X.inventoryItemId, X.scanTime, X.taxType
417
	FROM (SELECT i.itemId as itemId, i.purchaseId as purchaseId, p.receivedOn as purchaseDate, 
418
	s.quantity as quantity, l.unitPrice as unitPrice, l.nlc as nlc, l.brand as brand, 
419
	l.modelName as modelName, l.modelNumber as modelNumber, l.productGroup as category, 
420
	l.color as color , i.id as inventoryItemId, s.scannedAt as scanTime, CASE po.taxType 
421
	WHEN 0 THEN 'VAT' WHEN 1 THEN 'CST' WHEN 2 THEN 'CFORM' END as taxType FROM scanNew s 
422
	JOIN inventoryItem i on s.inventoryItemId= i.id JOIN transferLot t on (s.transferLotId= t.id) 
423
	JOIN purchase p on p.id= i.purchaseId JOIN purchaseorder po on p.purchaseOrder_id = po.id 
10689 manish.sha 424
	JOIN lineitem l on (l.purchaseOrder_id= p.purchaseOrder_id and l.itemId= i.itemId) 
425
	WHERE i.itemId in 
426
	<foreach item="itemId" index="index" collection="itemIds"
427
        open="(" separator="," close=")">
428
	 #{itemId} 
429
	</foreach> 
12357 manish.sha 430
	and t.destinationWarehouseId in (select id from inventory.warehouse where vendor_id= 40 
431
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source = 3) 
10689 manish.sha 432
	AND t.status in ('TRANSFER_COMPLETE','IN_TRANSIT','PARTIAL_TRANSFER') 
12658 manish.sha 433
	AND i.transferStatus is not null AND s.type='WAREHOUSE_TRANSFER_OUT' 
12357 manish.sha 434
	GROUP BY i.itemId, s.transferLotId, i.purchaseId, i.id order by s.scannedAt desc) 
435
	as X GROUP BY X.inventoryItemId 
436
	UNION SELECT Y.itemId, Y.purchaseId, Y.purchaseDate, Y.quantity, Y.unitPrice, Y.nlc, Y.brand, 
437
	Y.modelName, Y.modelNumber, Y.category, Y.color , Y.inventoryItemId, Y.scanTime, Y.taxType 
438
	FROM (SELECT i.itemId as itemId, i.purchaseId as purchaseId, p.receivedOn as purchaseDate, 
439
	s.quantity as quantity, l.unitPrice as unitPrice, l.nlc as nlc, l.brand as brand, l.modelName, 
440
	l.modelNumber as modelNumber, l.productGroup as category, l.color as color, 
441
	i.id as inventoryItemId, s.scannedAt as scanTime, CASE po.taxType 
442
	WHEN 0 THEN 'VAT' WHEN 1 THEN 'CST' WHEN 2 THEN 'CFORM' END as taxType FROM scanNew s 
443
	JOIN inventoryItem i on s.inventoryItemId = i.id JOIN purchase p on p.id= i.purchaseId 
444
	JOIN purchaseorder po on p.purchaseOrder_id = po.id 
445
	JOIN lineitem l on (l.purchaseOrder_id= p.purchaseOrder_id and l.itemId= i.itemId) 
446
	WHERE i.itemId in 
447
	<foreach item="itemId" index="index" collection="itemIds"
448
        open="(" separator="," close=")">
449
	 #{itemId} 
450
	</foreach> 
451
	and po.warehouseId in (select id from inventory.warehouse where vendor_id= 40 
452
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source = 3) 
453
	GROUP BY i.itemId, i.purchaseId, i.id ORDER BY s.scannedAt desc) as Y 
454
	GROUP BY Y.inventoryItemId) as Z GROUP BY Z.itemId, Z.purchaseId order by Z.purchaseId desc;
10689 manish.sha 455
</select>
456
 
457
<select id="getScansforPurchase" resultType="scan" parameterType="map" >
458
	SELECT s.id, s.inventoryItemId, s.warehouseId, s.type, s.scannedAt, s.quantity, s.orderId, s.remarks, s.transferLotId 
459
	FROM scanNew s 
460
	JOIN inventoryItem i on s.inventoryItemId = i.id 
461
	WHERE i.purchaseId= #{purchaseId} and s.type=#{scanType}
462
</select>
12800 manish.sha 463
 
464
<select id="getInventoryAgeConsideredItems" resultType="invAgeConsiderItems" parameterType = "java.lang.Long">
465
	SELECT ii.id, ii.itemId, ii.currentQuantity, ii.purchaseId, DATEDIFF(now(), MIN(s.scannedAt)) / 7 as age, 
12844 manish.sha 466
	l.productGroup as category, l.unitPrice as cost 
12800 manish.sha 467
	FROM inventoryItem ii JOIN scanNew s ON (s.inventoryItemId = ii.id) JOIN purchase p ON (p.id = ii.purchaseId) 
468
	JOIN lineitem l ON (l.purchaseOrder_id = p.purchaseOrder_id AND l.itemId = ii.itemId) 
469
	WHERE ((ii.lastScanType IN ('PURCHASE', 'SALE_RET', 'MARKED_GOOD')) OR (ii.currentQuantity>0) OR (ii.lastScanType IN ('SALE') and ii.currentQuantity = 1)) 
470
	AND ii.lastScanType != 'MARKED_BAD' AND (transferStatus is NULL or transferStatus != 'IN_TRANSIT') AND ii.itemId = #{itemId} 
471
	AND ii.physicalWarehouseId NOT IN (select id from inventory.warehouse where vendor_id= 40 and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8)) 
472
	GROUP BY ii.id, ii.itemId, ii.currentQuantity order by ii.id desc;
473
</select>
474
 
4500 mandeep.dh 475
</mapper>