Subversion Repositories SmartDukaan

Rev

Rev 13504 | Rev 14691 | 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 
13090 manish.sha 217
	(select i.itemId, sum(s.quantity) as inx from scanNew s 
6762 amar.kumar 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 
13090 manish.sha 224
	(select i.itemId, sum(s.quantity) as outx from scanNew s 
6762 amar.kumar 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 
13090 manish.sha 239
	(select i.itemId, sum(s.quantity) as inx from scanNew s 
10308 amar.kumar 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 
13090 manish.sha 248
	(select i.itemId, sum(s.quantity) as outx from scanNew s 
10308 amar.kumar 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">
13529 manish.sha 357
 	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, sum(quantity) 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' 
13529 manish.sha 361
 	AND s.warehouseId NOT IN (select id from inventory.warehouse where vendor_id= 40 and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8))
7216 amar.kumar 362
 	group by itemId, s.type
363
 </select>
364
 
365
 <select id = "getCompleteMovementNonSerializedInventoryByScans" resultType = "inventoryMovement" parameterType = "map">
7410 amar.kumar 366
 	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, sum(quantity) as quantity 
7216 amar.kumar 367
 	FROM inventoryItem i JOIN scanNew s ON i.id = s.inventoryItemId 
368
 	LEFT JOIN catalog.item c ON i.itemId = c.id 
13080 manish.sha 369
 	where s.scannedAt between #{startDate} and #{endDate} and c.type = 'NON_SERIALIZED'  
13529 manish.sha 370
 	AND s.warehouseId NOT IN (select id from inventory.warehouse where vendor_id= 40 and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8))  
7216 amar.kumar 371
 	group by itemId, s.type
372
 </select>
6630 amar.kumar 373
 
7410 amar.kumar 374
<select id = "getTransferrableWarehousesFromWarehouse" resultType = "java.lang.Long" parameterType = "java.lang.Long">
375
 	SELECT toWarehouseId  
376
 	FROM possibleWarehouseMovement  
377
 	WHERE fromWarehouseId = #{warehouseId}
378
 </select>
379
 
7957 amar.kumar 380
<select id = "getHistoricBadInventoryByScans" resultType = "inventoryAvailability" parameterType = "date">
13504 manish.sha 381
	SELECT badX.id as itemId, badX.brand, badX.model_name as modelName, badX.model_number as modelNumber, badX.color, sum(badX.Bad_quantity) as quantity 
382
	FROM (SELECT x.id, x.label as category,x.product_group,x.brand, x.model_name,x.model_number, x.color, (x.quantity-if(y.quantity is null,0,y.quantity)) as Bad_quantity, 
383
	x.physicalWarehouseId,x.purchaseId 
384
	FROM (SELECT it.id, ct.label, it.product_group,it.brand, it.model_name,it.model_number, it.color, 
385
	sum(s.quantity) as quantity, i.physicalWarehouseId,i.purchaseId FROM scanNew s 
386
	JOIN inventoryItem i on s.inventoryItemId = i.id JOIN purchase p on i.purchaseId= p.id 
387
	JOIN catalog.item it on i.itemId= it.id JOIN catalog.category ct on it.category = ct.id 
388
	WHERE s.type in ('MARKED_BAD','DOA_IN','SALE_RET_UNUSABLE','DOA_REJECTED') 
389
	AND s.scannedAt &gt; '2013-01-01' AND s.scannedAt &lt; #{date} 
390
	AND i.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)) 
391
	group by i.itemId,i.purchaseId) as x 
392
	LEFT OUTER JOIN (SELECT it.id, ct.label, it.product_group,it.brand, it.model_name,it.model_number,
393
	it.color, sum(s.quantity) as quantity, i.physicalWarehouseId, i.purchaseId 
394
	FROM scanNew s JOIN inventoryItem i on s.inventoryItemId = i.id JOIN purchase p on i.purchaseId= p.id 
395
	JOIN catalog.item it on i.itemId= it.id JOIN catalog.category ct on it.category = ct.id 
396
	WHERE s.type in ('DOA_OUT','BAD_SALE','MARKED_GOOD','BAD_PURCHASE_RETURN') 
397
	AND s.scannedAt &gt; '2013-01-01' AND s.scannedAt &lt; #{date} 
398
	AND i.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)) 
399
	group by i.itemId,i.purchaseId) as y 
400
	on x.id=y.id AND x.purchaseId=y.purchaseId 
401
	group by x.id,x.purchaseId having Bad_quantity>0) 
402
	as badX group by badX.id
7957 amar.kumar 403
</select>
7410 amar.kumar 404
 
405
<select id = "getScansForTransferLot" resultType = "scan" parameterType = "java.lang.Long">
406
	SELECT * 
407
	FROM scanNew
408
	WHERE transferLotId = #{id}
409
	AND type = 'WAREHOUSE_TRANSFER_OUT'
410
</select>
10120 manish.sha 411
 
412
<select id= "getScansForTransferLotAndInventoryItem" resultType = "scan" parameterType="map" >
413
	SELECT * 
414
	FROM scanNew
415
	WHERE transferLotId = #{transferLotId}
416
	AND inventoryItemId = #{inventoryItemId}
417
	AND type = 'WAREHOUSE_TRANSFER_OUT'
418
	LIMIT 1
419
</select>
10689 manish.sha 420
 
421
<select id="getAmazonTransferredSkuDetails" resultType= "amazonTransferredSkuDetail" parameterType="map">
12357 manish.sha 422
	SELECT Z.itemId, Z.purchaseId, Z.purchaseDate, sum(Z.quantity) as quantity, Z.unitPrice, Z.nlc, 
423
	Z.brand, Z.modelName, Z.modelNumber, Z.category, Z.color, Z.taxType  
424
	FROM  (SELECT X.itemId, X.purchaseId, X.purchaseDate, X.quantity, X.unitPrice, X.nlc, X.brand, 
425
	X.modelName, X.modelNumber, X.category, X.color , X.inventoryItemId, X.scanTime, X.taxType
426
	FROM (SELECT i.itemId as itemId, i.purchaseId as purchaseId, p.receivedOn as purchaseDate, 
427
	s.quantity as quantity, l.unitPrice as unitPrice, l.nlc as nlc, l.brand as brand, 
428
	l.modelName as modelName, l.modelNumber as modelNumber, l.productGroup as category, 
429
	l.color as color , i.id as inventoryItemId, s.scannedAt as scanTime, CASE po.taxType 
430
	WHEN 0 THEN 'VAT' WHEN 1 THEN 'CST' WHEN 2 THEN 'CFORM' END as taxType FROM scanNew s 
431
	JOIN inventoryItem i on s.inventoryItemId= i.id JOIN transferLot t on (s.transferLotId= t.id) 
432
	JOIN purchase p on p.id= i.purchaseId JOIN purchaseorder po on p.purchaseOrder_id = po.id 
10689 manish.sha 433
	JOIN lineitem l on (l.purchaseOrder_id= p.purchaseOrder_id and l.itemId= i.itemId) 
434
	WHERE i.itemId in 
435
	<foreach item="itemId" index="index" collection="itemIds"
436
        open="(" separator="," close=")">
437
	 #{itemId} 
438
	</foreach> 
12357 manish.sha 439
	and t.destinationWarehouseId in (select id from inventory.warehouse where vendor_id= 40 
440
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source = 3) 
10689 manish.sha 441
	AND t.status in ('TRANSFER_COMPLETE','IN_TRANSIT','PARTIAL_TRANSFER') 
12658 manish.sha 442
	AND i.transferStatus is not null AND s.type='WAREHOUSE_TRANSFER_OUT' 
12357 manish.sha 443
	GROUP BY i.itemId, s.transferLotId, i.purchaseId, i.id order by s.scannedAt desc) 
444
	as X GROUP BY X.inventoryItemId 
445
	UNION SELECT Y.itemId, Y.purchaseId, Y.purchaseDate, Y.quantity, Y.unitPrice, Y.nlc, Y.brand, 
446
	Y.modelName, Y.modelNumber, Y.category, Y.color , Y.inventoryItemId, Y.scanTime, Y.taxType 
447
	FROM (SELECT i.itemId as itemId, i.purchaseId as purchaseId, p.receivedOn as purchaseDate, 
448
	s.quantity as quantity, l.unitPrice as unitPrice, l.nlc as nlc, l.brand as brand, l.modelName, 
449
	l.modelNumber as modelNumber, l.productGroup as category, l.color as color, 
450
	i.id as inventoryItemId, s.scannedAt as scanTime, CASE po.taxType 
451
	WHEN 0 THEN 'VAT' WHEN 1 THEN 'CST' WHEN 2 THEN 'CFORM' END as taxType FROM scanNew s 
452
	JOIN inventoryItem i on s.inventoryItemId = i.id JOIN purchase p on p.id= i.purchaseId 
453
	JOIN purchaseorder po on p.purchaseOrder_id = po.id 
454
	JOIN lineitem l on (l.purchaseOrder_id= p.purchaseOrder_id and l.itemId= i.itemId) 
455
	WHERE i.itemId in 
456
	<foreach item="itemId" index="index" collection="itemIds"
457
        open="(" separator="," close=")">
458
	 #{itemId} 
459
	</foreach> 
460
	and po.warehouseId in (select id from inventory.warehouse where vendor_id= 40 
461
	and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source = 3) 
462
	GROUP BY i.itemId, i.purchaseId, i.id ORDER BY s.scannedAt desc) as Y 
463
	GROUP BY Y.inventoryItemId) as Z GROUP BY Z.itemId, Z.purchaseId order by Z.purchaseId desc;
10689 manish.sha 464
</select>
465
 
466
<select id="getScansforPurchase" resultType="scan" parameterType="map" >
467
	SELECT s.id, s.inventoryItemId, s.warehouseId, s.type, s.scannedAt, s.quantity, s.orderId, s.remarks, s.transferLotId 
468
	FROM scanNew s 
469
	JOIN inventoryItem i on s.inventoryItemId = i.id 
470
	WHERE i.purchaseId= #{purchaseId} and s.type=#{scanType}
471
</select>
12800 manish.sha 472
 
473
<select id="getInventoryAgeConsideredItems" resultType="invAgeConsiderItems" parameterType = "java.lang.Long">
474
	SELECT ii.id, ii.itemId, ii.currentQuantity, ii.purchaseId, DATEDIFF(now(), MIN(s.scannedAt)) / 7 as age, 
12844 manish.sha 475
	l.productGroup as category, l.unitPrice as cost 
12800 manish.sha 476
	FROM inventoryItem ii JOIN scanNew s ON (s.inventoryItemId = ii.id) JOIN purchase p ON (p.id = ii.purchaseId) 
477
	JOIN lineitem l ON (l.purchaseOrder_id = p.purchaseOrder_id AND l.itemId = ii.itemId) 
478
	WHERE ((ii.lastScanType IN ('PURCHASE', 'SALE_RET', 'MARKED_GOOD')) OR (ii.currentQuantity>0) OR (ii.lastScanType IN ('SALE') and ii.currentQuantity = 1)) 
479
	AND ii.lastScanType != 'MARKED_BAD' AND (transferStatus is NULL or transferStatus != 'IN_TRANSIT') AND ii.itemId = #{itemId} 
480
	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)) 
481
	GROUP BY ii.id, ii.itemId, ii.currentQuantity order by ii.id desc;
482
</select>
483
 
13529 manish.sha 484
<select id="getCompleteMovementForThirdPartyWarehouse" resultType = "inventoryMovement" parameterType = "map">
485
	SELECT itemId, brand, model_name as modelName, model_number as modelNumber, color, s.type, sum(quantity) as quantity 
486
 	FROM inventoryItem i JOIN scanNew s ON i.id = s.inventoryItemId 
487
 	LEFT JOIN catalog.item c ON i.itemId = c.id 
488
 	where s.scannedAt between #{startDate} and #{endDate} 
489
 	AND s.warehouseId IN (select id from inventory.warehouse where vendor_id= 40 and inventoryType = 'GOOD' and warehouseType ='OURS_THIRDPARTY' and source in (3,7,8))
490
 	group by itemId, s.type
491
</select>
492
 
4500 mandeep.dh 493
</mapper>