From 9e253a7fd8f57e1f7c3e7288a36167ff878ab28d Mon Sep 17 00:00:00 2001
From: YYC <1833023622@qq.com>
Date: 星期一, 06 十一月 2023 21:59:43 +0800
Subject: [PATCH] 库存管理添加粮权字段
---
 igds-inout/src/main/java/com/ld/igds/m/service/HPlanManageService.java |  308 ++++++++++++++++++++++++++++-----------------------
 1 files changed, 170 insertions(+), 138 deletions(-)
diff --git a/igds-inout/src/main/java/com/ld/igds/m/service/HPlanManageService.java b/igds-inout/src/main/java/com/ld/igds/m/service/HPlanManageService.java
index 4f587bc..fa53772 100644
--- a/igds-inout/src/main/java/com/ld/igds/m/service/HPlanManageService.java
+++ b/igds-inout/src/main/java/com/ld/igds/m/service/HPlanManageService.java
@@ -3,8 +3,8 @@
 import com.bstek.bdf2.core.orm.hibernate.HibernateDao;
 import com.bstek.dorado.data.provider.Page;
 import com.ld.igds.m.InoutManageUtil;
-import com.ld.igds.models.MPlan;
-import com.ld.igds.models.MPlanDetail;
+import com.ld.igds.models.InoutPlan;
+import com.ld.igds.models.InoutPlanDetail;
 import com.ld.igds.util.ContextUtil;
 import org.apache.commons.lang3.StringUtils;
 import org.hibernate.Session;
@@ -19,165 +19,197 @@
 @Component
 public class HPlanManageService extends HibernateDao {
 
-	public void pagePlan(Page<MPlan> page, Map<String, Object> param)
-			throws Exception {
-		String hql = " from " + MPlan.class.getName()
-				+ " where companyId =:companyId and deptId =:deptId";
+    public void pagePlan(Page<InoutPlan> page, Map<String, Object> param)
+            throws Exception {
+        String hql = " from " + InoutPlan.class.getName()
+                + " where companyId =:companyId and deptId =:deptId";
 
-		Map<String, Object> args = new HashMap<String, Object>();
-		args.put("companyId", ContextUtil.getCompanyId());
-		args.put("deptId", ContextUtil.subDeptId(null));
+        Map<String, Object> args = new HashMap<String, Object>();
+        args.put("companyId", ContextUtil.getCompanyId());
+        args.put("deptId", ContextUtil.subDeptId(null));
 
-		if (null != param) {
-			String str = (String) param.get("id");
-			if (StringUtils.isNotEmpty(str)) {
-				hql += " and id like:id";
-				args.put("id", "%" + str + "%");
-			}
-			Integer year = (Integer) param.get("year");
-			if (null != year) {
-				hql += " and year =:year";
-				args.put("year", String.valueOf(year));
-			}
-			str = (String) param.get("type");
-			if (StringUtils.isNotEmpty(str)) {
-				hql += " and type =:type";
-				args.put("type", str);
-			}
-			str = (String) param.get("referenceNumber");
-			if (StringUtils.isNotEmpty(str)) {
-				hql += " and referenceNumber like:referenceNumber";
-				args.put("referenceNumber", "%" + str + "%");
-			}
-			str = (String) param.get("name");
-			if (StringUtils.isNotEmpty(str)) {
-				hql += " and name like:name";
-				args.put("name", "%" + str + "%");
-			}
-			str = (String) param.get("key");
-			if (StringUtils.isNotEmpty(str)) {
-				hql += " and (name like :name or referenceNumber like:referenceNumber) ";
-				args.put("name", "%" + str + "%");
-				args.put("referenceNumber", "%" + str + "%");
-			}
-		}
+        if (null != param) {
+            String str = (String) param.get("id");
+            if (StringUtils.isNotEmpty(str)) {
+                hql += " and id like:id";
+                args.put("id", "%" + str + "%");
+            }
+            Integer year = (Integer) param.get("year");
+            if (null != year) {
+                hql += " and year =:year";
+                args.put("year", String.valueOf(year));
+            }
+            str = (String) param.get("type");
+            if (StringUtils.isNotEmpty(str)) {
+                hql += " and type =:type";
+                args.put("type", str);
+            }
+            str = (String) param.get("referenceNumber");
+            if (StringUtils.isNotEmpty(str)) {
+                hql += " and referenceNumber like:referenceNumber";
+                args.put("referenceNumber", "%" + str + "%");
+            }
+            str = (String) param.get("name");
+            if (StringUtils.isNotEmpty(str)) {
+                hql += " and name like:name";
+                args.put("name", "%" + str + "%");
+            }
+            str = (String) param.get("key");
+            if (StringUtils.isNotEmpty(str)) {
+                hql += " and (name like :name or referenceNumber like:referenceNumber) ";
+                args.put("name", "%" + str + "%");
+                args.put("referenceNumber", "%" + str + "%");
+            }
+        }
 
-		String count = "select count(*) " + hql;
+        String count = "select count(*) " + hql;
 
-		hql += " order by createTime desc";
+        hql += " order by createTime desc";
 
-		this.pagingQuery(page, hql, count, args);
-	}
+        this.pagingQuery(page, hql, count, args);
+    }
 
+    public List<InoutPlan> listPlan() {
+        String hql = " from " + InoutPlan.class.getName()
+                + " where companyId =:companyId and deptId =:deptId";
 
+        Map<String, Object> args = new HashMap<String, Object>();
+        args.put("companyId", ContextUtil.getCompanyId());
+        args.put("deptId", ContextUtil.subDeptId(null));
 
-	public List<MPlanDetail> listPlanDetail(String planId) {
-		
-		String hql = " from " + MPlanDetail.class.getName();
-		
-		if(null != planId){
-			hql += " where planId=:planId ";
-			Map<String, Object> args = new HashMap<String, Object>();
-			args.put("planId", planId);
-			return this.query(hql, args);
-		}
+        return this.query(hql, args);
+    }
 
-		return this.query(hql);
-	}
+    public List<InoutPlanDetail> listPlanDetail(String planId) {
 
-	@Transactional
-	public String delPlan(MPlan data) {
-		Session session = this.getSessionFactory().openSession();
-		try {
-			if (null != data.getId()) {
-				this.delPlanDetailByPlanId(data.getId(), session);
-				session.delete(data);
-			}
-		} catch (Exception e) {
-			e.printStackTrace();
-		} finally {
-			session.flush();
-			session.close();
-		}
-		return null;
-	}
+        String hql = " from " + InoutPlanDetail.class.getName();
 
-	public String delPlanDetail(MPlanDetail data) {
-		Session session = this.getSessionFactory().openSession();
-		try {
-			if (null != data.getId()) {
-				session.delete(data);
-			}
-		} catch (Exception e) {
-			e.printStackTrace();
-		} finally {
-			session.flush();
-			session.close();
-		}
-		return null;
-	}
+        if (null != planId) {
+            hql += " where planId=:planId ";
+            Map<String, Object> args = new HashMap<String, Object>();
+            args.put("planId", planId);
+            return this.query(hql, args);
+        }
 
-	private void delPlanDetailByPlanId(String id, Session session) {
-		String hql = " delete from " + MPlanDetail.class.getName()
-				+ " where planId=:planId";
+        return this.query(hql);
+    }
 
-		session.createQuery(hql).setString("planId", id).executeUpdate();
-	}
+    @Transactional
+    public String delPlan(InoutPlan data) {
+        Session session = this.getSessionFactory().openSession();
+        try {
+            if (null != data.getId()) {
+                this.delPlanDetailByPlanId(data.getId(), session);
+                session.delete(data);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        } finally {
+            session.flush();
+            session.close();
+        }
+        return null;
+    }
 
-	public void savePlan(MPlan data) {
-		if (null == data.getCompanyId()) {
-			data.setCompanyId(ContextUtil.getCompanyId());
-		}
+    public String delPlanDetail(InoutPlanDetail data) {
+        Session session = this.getSessionFactory().openSession();
+        try {
+            if (null != data.getId()) {
+                session.delete(data);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        } finally {
+            session.flush();
+            session.close();
+        }
+        return null;
+    }
+
+    private void delPlanDetailByPlanId(String id, Session session) {
+        String hql = " delete from " + InoutPlanDetail.class.getName()
+                + " where planId=:planId";
+
+        session.createQuery(hql).setString("planId", id).executeUpdate();
+    }
+
+    public void savePlan(InoutPlan data) {
+        if (null == data.getCompanyId()) {
+            data.setCompanyId(ContextUtil.getCompanyId());
+        }
         if (null == data.getDeptId()) {
             data.setDeptId(ContextUtil.subDeptId(null));
         }
-		Session session = this.getSessionFactory().openSession();
-		try {
-			if (null == data.getId()) {
-                List<MPlan> list = getPlanId(data);
+        Session session = this.getSessionFactory().openSession();
+        try {
+            if (null == data.getId()) {
+                List<InoutPlan> list = getPlanId(data);
                 data.setId(InoutManageUtil.createPlanId(data.getType(), data.getYear(), list));
                 data.setCreateUser(ContextUtil.getLoginUserCName());
                 data.setCreateTime(new Date());
-				session.save(data);
-			} else {
-				session.update(data);
-			}
-			savePlanDetail(data.getDetails(), data.getId(), session);
-		} catch (Exception e) {
-			e.printStackTrace();
-		} finally {
-			session.flush();
-			session.close();
-		}
-	}
+                session.save(data);
+            } else {
+                session.update(data);
+            }
+            savePlanDetail(data.getDetails(), data.getId(), session);
+        } catch (Exception e) {
+            e.printStackTrace();
+        } finally {
+            session.flush();
+            session.close();
+        }
+    }
 
-	private void savePlanDetail(List<MPlanDetail> details, String planId,
-			Session session) {
-		if (null == details || details.isEmpty())
-			return;
-		for (MPlanDetail planDetail : details) {
-			if (null == planDetail.getId()) {
-				planDetail.setPlanId(planId);
-				planDetail.setId(ContextUtil.getUUID());
-				planDetail.setCreateTime(new Date());
-				session.save(planDetail);
-			} else {
-				session.update(planDetail);
-			}
-		}
-	}
+    private void savePlanDetail(List<InoutPlanDetail> details, String planId,
+                                Session session) {
+        if (null == details || details.isEmpty())
+            return;
+        for (InoutPlanDetail planDetail : details) {
+            if (null == planDetail.getId()) {
+                planDetail.setUpdateTime(new Date());
+                planDetail.setPlanId(planId);
+                planDetail.setId(ContextUtil.getUUID());
+                session.save(planDetail);
+            } else {
+                planDetail.setUpdateTime(new Date());
+                session.update(planDetail);
+            }
+        }
+    }
 
-	public List<MPlan> getPlanId(MPlan plan){
-		String hql = " from " + MPlan.class.getName()
-				+ " where companyId =:companyId and deptId =:deptId and year =:year";
+    public List<InoutPlan> getPlanId(InoutPlan plan) {
+        String hql = " from " + InoutPlan.class.getName()
+                + " where companyId =:companyId and deptId =:deptId and year =:year";
 
-		Map<String,Object> args = new HashMap<String,Object>();
-		args.put("companyId", plan.getCompanyId());
-		args.put("deptId", plan.getDeptId());
-		args.put("year", plan.getYear());
+        Map<String, Object> args = new HashMap<String, Object>();
+        args.put("companyId", plan.getCompanyId());
+        args.put("deptId", plan.getDeptId());
+        args.put("year", plan.getYear());
 
-		hql += " order by createTime desc";
+        hql += " order by createTime desc";
 
-		return this.query(hql, args);
-	}
+        return this.query(hql, args);
+    }
+
+    public void pagePlanDetail(Page<InoutPlanDetail> page, Map<String, Object> param)
+            throws Exception {
+        String hql = " from " + InoutPlanDetail.class.getName()
+                + " where 1=1 ";
+
+        Map<String, Object> args = new HashMap<String, Object>();
+
+        if (null != param) {
+            String str = (String) param.get("key");
+            if (StringUtils.isNotEmpty(str)) {
+                hql += " and year like :year ";
+                args.put("year", "%" + str + "%");
+            }
+        }
+
+        String count = "select count(*) " + hql;
+
+        hql += " order by updateTime desc";
+
+        this.pagingQuery(page, hql, count, args);
+    }
 }
--
Gitblit v1.9.3