|  | @ -1211,6 +1211,61 @@ public class MedicinedeviceService  extends BaseJpaService<Mediicinedevice, Medi
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         JSONObject jsonObject = new JSONObject();
 | 
	
		
			
				|  |  |         jsonObject.put("device",device);
 | 
	
		
			
				|  |  |         jsonObject.put("totalCargo", device.getAisles());   //货道合并/解离
 | 
	
		
			
				|  |  |         //设备容量
 | 
	
		
			
				|  |  |         jsonObject.put("deviceCapacity", device.getCapacity());
 | 
	
		
			
				|  |  |         String tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                 "\tsum(t.qty)\n" +
 | 
	
		
			
				|  |  |                 "FROM\n" +
 | 
	
		
			
				|  |  |                 "\tt_mediicinecabinet_inventory t\n" +
 | 
	
		
			
				|  |  |                 "WHERE\n" +
 | 
	
		
			
				|  |  |                 "\tt.id_device = '"+device.getId()+"'\n" +
 | 
	
		
			
				|  |  |                 "AND (t.state = '1' OR t.state = '21')\n" +
 | 
	
		
			
				|  |  |                 "AND t.shelf_status = '1'";
 | 
	
		
			
				|  |  |         int inStock = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |         //在架库存数
 | 
	
		
			
				|  |  |         jsonObject.put("inStock", inStock);
 | 
	
		
			
				|  |  |         jsonObject.put("inStockRate", new BigDecimal((inStock * 1.0) / Integer.parseInt(device.getCapacity())).setScale(2, BigDecimal.ROUND_HALF_UP));
 | 
	
		
			
				|  |  |         //缺货库存Out of stock
 | 
	
		
			
				|  |  |         tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                 "\tsum(\n" +
 | 
	
		
			
				|  |  |                 "\t\tt.cargo_capacity - cast(t.qty AS UNSIGNED)\n" +
 | 
	
		
			
				|  |  |                 "\t)\n" +
 | 
	
		
			
				|  |  |                 "FROM\n" +
 | 
	
		
			
				|  |  |                 "\tt_mediicinecabinet_inventory t\n" +
 | 
	
		
			
				|  |  |                 "WHERE\n" +
 | 
	
		
			
				|  |  |                 "\tt.id_device = '"+ device.getId() +"'\n" +
 | 
	
		
			
				|  |  |                 "AND (t.state = '1' OR t.state = '21')";
 | 
	
		
			
				|  |  |         int outOfStock = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |         //在架库存数
 | 
	
		
			
				|  |  |         jsonObject.put("outOfStock", outOfStock);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |         tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                 "\tCOUNT(DISTINCT(t.id))\n" +
 | 
	
		
			
				|  |  |                 "FROM\n" +
 | 
	
		
			
				|  |  |                 "\tt_mediicinecabinet_inventory t\n" +
 | 
	
		
			
				|  |  |                 "WHERE\n" +
 | 
	
		
			
				|  |  |                 "\tt.id_device = '"+device.getId()+"'\n" +
 | 
	
		
			
				|  |  |                 "and cast(t.qty AS UNSIGNED) < t.num\n" +
 | 
	
		
			
				|  |  |                 "AND (t.state = '1'\n" +
 | 
	
		
			
				|  |  |                 "OR t.state = '21')";
 | 
	
		
			
				|  |  |         //预警货道
 | 
	
		
			
				|  |  |         int earlyWarningCargo = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |         jsonObject.put("earlyWarningCargo", earlyWarningCargo);
 | 
	
		
			
				|  |  |         tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                 "\tCOUNT(DISTINCT(t.id))\n" +
 | 
	
		
			
				|  |  |                 "FROM\n" +
 | 
	
		
			
				|  |  |                 "\tt_mediicinecabinet_inventory t\n" +
 | 
	
		
			
				|  |  |                 "WHERE\n" +
 | 
	
		
			
				|  |  |                 "\tt.id_device = '" + device.getId() + "'\n" +
 | 
	
		
			
				|  |  |                 "and t.cargo_state = '0'\n" +
 | 
	
		
			
				|  |  |                 "AND (t.state = '1'\n" +
 | 
	
		
			
				|  |  |                 "OR t.state = '21')";
 | 
	
		
			
				|  |  |         //关闭货道
 | 
	
		
			
				|  |  |         int closedCargo = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |         jsonObject.put("closedCargo", closedCargo);
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |         //1补货,2换货,3上架,4下架
 | 
	
		
			
				|  |  |         jsonObject.put("inventoryList",inventoryRecordDao.findMedicineDrugInventoryRecordsByDeviceIdAndEquNumAndType(device.getId(), device.getEquNum(),"1"));
 | 
	
		
			
				|  |  |         result.put("response",ConstantUtils.SUCCESS);
 | 
	
	
		
			
				|  | @ -1768,41 +1823,49 @@ public class MedicinedeviceService  extends BaseJpaService<Mediicinedevice, Medi
 | 
	
		
			
				|  |  |             deviceList = hibenateUtils.createSQLQuery(sencodSql);
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  |         for (Map<String, Object> stringObjectMap : deviceList) {
 | 
	
		
			
				|  |  |             String tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                     "\tsum(t.qty)\n" +
 | 
	
		
			
				|  |  |             String tempSql = "";
 | 
	
		
			
				|  |  |             int number;
 | 
	
		
			
				|  |  |             //待补商品数量
 | 
	
		
			
				|  |  |             tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                     "\tsum(\n" +
 | 
	
		
			
				|  |  |                     "\t\tt.cargo_capacity - cast(t.qty AS UNSIGNED)\n" +
 | 
	
		
			
				|  |  |                     "\t)\n" +
 | 
	
		
			
				|  |  |                     "FROM\n" +
 | 
	
		
			
				|  |  |                     "\tt_mediicinecabinet_inventory t\n" +
 | 
	
		
			
				|  |  |                     "WHERE\n" +
 | 
	
		
			
				|  |  |                     "\tconcat(IFNULL(t.`id_device`, ''), IFNULL(t.`equ_num`, '')) like '%" + stringObjectMap.get("equNum") +"%'\n" +
 | 
	
		
			
				|  |  |                     "AND t.shelf_status = 1";
 | 
	
		
			
				|  |  |             //库存
 | 
	
		
			
				|  |  |             Integer qty = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |             qty = qty == null ? 0 : qty;
 | 
	
		
			
				|  |  |             stringObjectMap.put("daibuQty", Integer.parseInt(stringObjectMap.get("capacity").toString()) - qty);
 | 
	
		
			
				|  |  |                     "\tt.id_device = '"+stringObjectMap.get("id").toString()+"'\n" +
 | 
	
		
			
				|  |  |                     "AND (t.state = '1' OR t.state = '21')";
 | 
	
		
			
				|  |  |             number = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |             stringObjectMap.put("daibushangpinshuliang", number);
 | 
	
		
			
				|  |  |             //未设置商品货道
 | 
	
		
			
				|  |  |             tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                     "\tCOUNT(DISTINCT(id))\n" +
 | 
	
		
			
				|  |  |                     "\tcount(DISTINCT(t.id))\n" +
 | 
	
		
			
				|  |  |                     "FROM\n" +
 | 
	
		
			
				|  |  |                     "\tt_mediicinecabinet_inventory t\n" +
 | 
	
		
			
				|  |  |                     "WHERE\n" +
 | 
	
		
			
				|  |  |                     "\tconcat(IFNULL(t.`id_device`, ''), IFNULL(t.`equ_num`, '')) like '%" + stringObjectMap.get("equNum") +"%'\n" +
 | 
	
		
			
				|  |  |                     "AND t.shelf_status = 0";
 | 
	
		
			
				|  |  |             Integer xiajiaQty = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |             if (xiajiaQty != null) {
 | 
	
		
			
				|  |  |                 stringObjectMap.put("xiajiaQty", xiajiaQty);
 | 
	
		
			
				|  |  |             }
 | 
	
		
			
				|  |  | //            tempSql = "select count(distinct(id)) from t_mediicine_stockrecord_detail";
 | 
	
		
			
				|  |  | //            tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  | //                    "\tcreate_time\n" +
 | 
	
		
			
				|  |  | //                    "FROM\n" +
 | 
	
		
			
				|  |  | //                    "\tt_mediicine_stockrecord_detail\n" +
 | 
	
		
			
				|  |  | //                    "ORDER BY\n" +
 | 
	
		
			
				|  |  | //                    "\tcreate_time DESC\n" +
 | 
	
		
			
				|  |  | //                    "LIMIT 1";
 | 
	
		
			
				|  |  | //            Date buhuoDate = jdbcTemplate.queryForObject(tempSql, Date.class);
 | 
	
		
			
				|  |  | //            if (buhuoDate != null) {
 | 
	
		
			
				|  |  | //                stringObjectMap.put("buhuoTime", DateUtil.dateToStr(buhuoDate, "yyyy-MM-dd HH:mm:ss" ));
 | 
	
		
			
				|  |  | //            }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |                     "\tt.id_device = '" + stringObjectMap.get("id").toString() + "'\n" +
 | 
	
		
			
				|  |  |                     "AND t.org_code IS NULL\n" +
 | 
	
		
			
				|  |  |                     "AND t.drug_code IS NULL\n" +
 | 
	
		
			
				|  |  |                     "AND (t.state = '1' OR t.state = '21')";
 | 
	
		
			
				|  |  |             number = jdbcTemplate.queryForObject(tempSql, Integer.class);
 | 
	
		
			
				|  |  |             stringObjectMap.put("weishezhishangpinhuodao", number);
 | 
	
		
			
				|  |  |             //空置率
 | 
	
		
			
				|  |  |             stringObjectMap.put("kongzhilv",
 | 
	
		
			
				|  |  |                     new BigDecimal((number * 1.0) / Integer.parseInt(stringObjectMap.get("aisles").toString())).setScale(2, BigDecimal.ROUND_HALF_UP));
 | 
	
		
			
				|  |  |             //上一次补货时间
 | 
	
		
			
				|  |  |             tempSql = "SELECT\n" +
 | 
	
		
			
				|  |  |                     "\tcreate_time\n" +
 | 
	
		
			
				|  |  |                     "FROM\n" +
 | 
	
		
			
				|  |  |                     "\tt_medicine_drug_inventory_record\n" +
 | 
	
		
			
				|  |  |                     "WHERE\n" +
 | 
	
		
			
				|  |  |                     "\tdevice_id = '" + stringObjectMap.get("id").toString() + "'\n" +
 | 
	
		
			
				|  |  |                     "and type = '1'\n" +
 | 
	
		
			
				|  |  |                     "ORDER BY\n" +
 | 
	
		
			
				|  |  |                     "\tcreate_time DESC\n" +
 | 
	
		
			
				|  |  |                     "LIMIT 1;";
 | 
	
		
			
				|  |  |             Date lastBuhuo = jdbcTemplate.queryForObject(tempSql, Date.class);
 | 
	
		
			
				|  |  |             stringObjectMap.put("shangyicibuhuoshijian",
 | 
	
		
			
				|  |  |                     lastBuhuo== null ? "" : DateUtil.dateToStr(lastBuhuo, "yyyy-MM-dd HH:mm:ss"));
 | 
	
		
			
				|  |  |         }
 | 
	
		
			
				|  |  | 
 | 
	
		
			
				|  |  |         result.put("response", ConstantUtils.SUCCESS);
 |