AutoDockItemService.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. package service;
  2. import beans.parameter.Parameter;
  3. import com.alibaba.fastjson.JSONArray;
  4. import com.alibaba.fastjson.JSONObject;
  5. import common.BaseClass;
  6. import common.ServiceController;
  7. import common.YosException;
  8. import common.data.*;
  9. import common.data.db.DBConnect;
  10. import org.apache.commons.lang.StringEscapeUtils;
  11. import org.apache.commons.lang.StringUtils;
  12. import restcontroller.webmanage.sale.item.Item;
  13. import utility.ERPDocking;
  14. import java.text.SimpleDateFormat;
  15. import java.util.ArrayList;
  16. import java.util.Calendar;
  17. import java.util.Date;
  18. import java.util.TimeZone;
  19. public class AutoDockItemService extends ServiceController {
  20. String[] siteids = {"CCYOSG", "DLB"};
  21. @Override
  22. public void serviceRun() throws YosException {
  23. for (String siteid : siteids) {
  24. if (dbConnect.runSqlQuery("SELECT 1 from sys_site WHERE siteid='" + siteid + "'").isEmpty()) {
  25. continue;
  26. }
  27. String paramname = "AutoDockItemServiceTime" + "_" + siteid;
  28. SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  29. simpleDateFormat.setTimeZone(TimeZone.getTimeZone("Etc/GMT-8"));
  30. String AutoDockItemServiceTime = getAutoDockItemServiceTime(paramname, simpleDateFormat);
  31. ArrayList<String> sqlList = new ArrayList<>();
  32. Rows itemRows = dbConnect.runSqlQuery("SELECT itemid,itemno from plm_item WHERE siteid = '" + siteid + "' AND status = '新建' ");
  33. Rows itemRowsAll = dbConnect.runSqlQuery("SELECT itemid,itemno,status from plm_item WHERE siteid = '" + siteid + "'");
  34. //单位
  35. Rows unitRows = dbConnect.runSqlQuery("SELECT unitid,unitname from plm_unit WHERE siteid = '" + siteid + "'");
  36. RowsMap unitRowsMap = unitRows.toRowsMap("unitname");
  37. RowsMap itemRowsMap = itemRows.toRowsMap("itemno");
  38. RowsMap itemRowsMapAll = itemRowsAll.toRowsMap("itemno");
  39. ERPDocking erpDocking = new ERPDocking(siteid);
  40. JSONArray jsonArray = erpDocking.getErpItemRows(AutoDockItemServiceTime, 100000, 1);
  41. if (!jsonArray.isEmpty()) {
  42. for (Object object : jsonArray) {
  43. JSONObject jsonObject = (JSONObject) object;
  44. System.err.println(jsonObject);
  45. if (!itemRowsMapAll.containsKey(jsonObject.getString("fitemno"))) {
  46. long itemid = createTableID("plm_item");
  47. SQLFactory sqlFactory = new SQLFactory(new Item(jsonObject), "货品档案新增");
  48. sqlFactory.addParameter("siteid", siteid);
  49. sqlFactory.addParameter("itemid", itemid);
  50. sqlFactory.addParameter("username", "admin");
  51. sqlFactory.addParameter("userid", 1);
  52. sqlFactory.addParameter("itemno", jsonObject.getString("fitemno"));
  53. sqlFactory.addParameter("marketingcategory", "");
  54. if (unitRowsMap.containsKey(jsonObject.getString("funit"))) {
  55. sqlFactory.addParameter("unitid", unitRowsMap.get(jsonObject.getString("funit")).get(0).getLong("unitid"));
  56. } else {
  57. sqlFactory.addParameter("unitid", 0);
  58. }
  59. sqlFactory.addParameter("isauxunit", 0);
  60. sqlFactory.addParameter("unitgroupid", "null");
  61. sqlFactory.addParameter("itemname", jsonObject.getString("fitemname"));
  62. sqlFactory.addParameter("isonsale", 0);
  63. sqlFactory.addParameter("model", jsonObject.getString("fmodel"));
  64. sqlFactory.addParameter("spec", jsonObject.getString("spec"));
  65. // 订单起订量
  66. sqlFactory.addParameter("orderminqty", 1);
  67. // 订单增量
  68. sqlFactory.addParameter("orderaddqty", 1);
  69. // 订单起订量控制单位(0:主单位;1:辅助单位)
  70. sqlFactory.addParameter("orderminqty_auxunit", 0);
  71. // 订单增量控制单位(0:主单位;1:辅助单位)
  72. sqlFactory.addParameter("orderaddqty_auxunit", 0);
  73. // 说明
  74. sqlFactory.addParameter("remarks", "");
  75. // 商品条形码
  76. sqlFactory.addParameter("barcode", "");
  77. // 是否单品管理
  78. sqlFactory.addParameter("skucontrol", 0);
  79. // 是否批次管理
  80. sqlFactory.addParameter("batchcontrol", jsonObject.getBooleanValue("fisbatch"));
  81. // 毛重(g)
  82. sqlFactory.addParameter("grossweight", 0);
  83. // 净重(g)
  84. sqlFactory.addParameter("weight", 0);
  85. // 高度(mm)
  86. sqlFactory.addParameter("height", 0);
  87. // 宽度(mm)
  88. sqlFactory.addParameter("width", 0);
  89. // 长度(mm)
  90. sqlFactory.addParameter("length", 0);
  91. // 交期
  92. sqlFactory.addParameter("delivery", 1);
  93. // 牌价
  94. sqlFactory.addParameter("marketprice", 0);
  95. // 是否工具
  96. sqlFactory.addParameter("istool", 0);
  97. // 产品标准
  98. sqlFactory.addParameter("standards", "");
  99. // 库存缺货标准
  100. sqlFactory.addParameter("stockstatus2", 1);
  101. // 库存充足标准
  102. sqlFactory.addParameter("stockstatus1", 1);
  103. // 保修期(年)
  104. sqlFactory.addParameter("warrantyday", 1);
  105. // 是否营销物料
  106. sqlFactory.addParameter("iswuliao", 0);
  107. // 是否服务物料
  108. sqlFactory.addParameter("isservice", 0);
  109. sqlFactory.addParameter("materialschemeid", 0);
  110. sqlFactory.addParameter("colorschemeid", 0);
  111. sqlFactory.addParameter("cheekschemeid", 0);
  112. sqlFactory.addParameter("color", jsonObject.getStringValue("fcolor"));
  113. sqlFactory.addParameter("cheek", jsonObject.getStringValue("fsizedescription"));
  114. sqlFactory.addParameter("delistingstatus", "");
  115. sqlFactory.addParameter("ismodule", 0);
  116. sqlFactory.addParameter("packageqty", (StringUtils.isBlank(jsonObject.getStringValue("fpackqty")) ? "0" : jsonObject.getStringValue("fpackqty")));
  117. sqlFactory.addParameter("iswoodproducts", 0);
  118. sqlFactory.addParameter("sa_customschemeid", 0);
  119. sqlFactory.addParameter("financeclasstype", jsonObject.getStringValue("fdescription"));
  120. sqlFactory.addParameter("stockno", jsonObject.getStringValue("fstockno"));
  121. sqlFactory.addParameter("volume", jsonObject.getBigDecimalValue("fvolume"));
  122. sqlFactory.addParameter("pricingmetod", "2");
  123. sqlList.add(sqlFactory.getSQL());
  124. // 货品档案扩展属性字段表
  125. sqlFactory = new SQLFactory(new Item(jsonObject), "货品档案-扩展新增");
  126. sqlFactory.addParameter("siteid", siteid);
  127. sqlFactory.addParameter("userid", 1);
  128. sqlFactory.addParameter("username", "admin");
  129. sqlFactory.addParameter("plm_itemextendid", createTableID("plm_itemextend"));
  130. sqlFactory.addParameter("itemid", itemid);
  131. sqlFactory.addParameter("material", jsonObject.getString("fmaterialdes"));
  132. sqlFactory.addParameter("pressure", "");
  133. sqlFactory.addParameter("caliber", "");
  134. sqlFactory.addParameter("butterflyplatedrive", "");
  135. sqlFactory.addParameter("connection", "");
  136. sqlFactory.addParameter("valveplatematerial", "");
  137. sqlFactory.addParameter("bodymaterial", "");
  138. sqlFactory.addParameter("actuatortype", "");
  139. sqlFactory.addParameter("actuatorbrand", "");
  140. sqlFactory.addParameter("isbutterfly", 0);
  141. sqlFactory.addParameter("erpitemno", jsonObject.getString("fitemno"));
  142. sqlFactory.addParameter("erpitemname", jsonObject.getString("fitemname"));
  143. sqlFactory.addParameter("specalnote", "");
  144. sqlFactory.addParameter("prodline", "");
  145. sqlFactory.addParameter("device", "");
  146. sqlList.add(sqlFactory.getSQL());
  147. } else {
  148. // sqlList.add("update plm_item set itemname='" + jsonObject.getString("fitemname") + "',volume='" + jsonObject.getStringValue("fvolume") + "',packageqty='" + (StringUtils.isBlank(jsonObject.getStringValue("fpackqty")) ? "0" : jsonObject.getStringValue("fpackqty")) + "' where itemid=" + itemRowsMapAll.get(jsonObject.getString("fitemno")).get(0).getLong("itemid"));
  149. // System.out.println("update plm_item set itemname='" + jsonObject.getString("fitemname") + "',volume='" + jsonObject.getStringValue("fvolume") + "',packageqty='" + (StringUtils.isBlank(jsonObject.getStringValue("fpackqty")) ? "0" : jsonObject.getStringValue("fpackqty")) + "' where itemid=" + itemRowsMapAll.get(jsonObject.getString("fitemno")).get(0).getLong("itemid"));
  150. Long itemid = itemRowsMapAll.get(jsonObject.getString("fitemno")).get(0).getLong("itemid");
  151. String spec = jsonObject.getStringValue("spec");//尺寸
  152. String cheek = jsonObject.getStringValue("fsizedescription");//工艺
  153. String material = jsonObject.getStringValue("fmaterialdes");//选项
  154. String color = jsonObject.getStringValue("fcolor");//颜色
  155. boolean isonsale = true;
  156. if (dbConnect.runSqlQuery("SELECT 1 FROM plm_item t1 LEFT JOIN plm_itemextend t2 ON t2.itemid=t1.itemid AND t2.siteid=t1.siteid " +
  157. "WHERE spec='" + spec + "' AND cheek='" + cheek + "' AND material='" + material + "' AND color='" + color + "'").isEmpty()) {
  158. isonsale = false;
  159. sqlList.add("delete from sa_itemgroupmx WHERE itemid=" + itemid + " and siteid='" + siteid + "' ");
  160. Rows rows = dbConnect.runSqlQuery("SELECT sa_itemgroupid from sa_itemgroupmx WHERE itemid=" + itemid + " and siteid='" + siteid + "' ");
  161. ArrayList<Long> sa_itemgroupids = rows.toArrayList("sa_itemgroupid", new ArrayList<>());
  162. for (Long sa_itemgroupid : sa_itemgroupids) {
  163. int count = dbConnect.runSqlQuery(0, "SELECT count(0) count from sa_itemgroupmx WHERE sa_itemgroupid=" + sa_itemgroupid + " and siteid='" + siteid + "' ").getInteger("count");
  164. if (count == 1) {
  165. sqlList.add("delete from sa_itemgroup WHERE sa_itemgroupid=" + sa_itemgroupid + " and siteid='" + siteid + "' ");
  166. }
  167. }
  168. }
  169. boolean iscustomsize = false;
  170. if (spec.equals("custom") || cheek.equals("custom") || material.equals("custom") || color.equals("custom")) {
  171. iscustomsize = true;
  172. }
  173. UpdateSQL updateSQL = SQLFactory.createUpdateSQL(new DBConnect(), "plm_item");
  174. updateSQL.setWhere("itemid", itemid);
  175. updateSQL.setSiteid(siteid);
  176. updateSQL.setValue("isonsale", isonsale);
  177. updateSQL.setValue("iscustomsize", iscustomsize);
  178. updateSQL.setValue("itemname", jsonObject.getString("fitemname"));
  179. updateSQL.setValue("volume", jsonObject.getStringValue("fvolume"));
  180. updateSQL.setValue("packageqty", (StringUtils.isBlank(jsonObject.getStringValue("fpackqty")) ? "0" : jsonObject.getStringValue("fpackqty")));
  181. updateSQL.setValue("itemno", jsonObject.getString("fitemno"));//商品编码
  182. updateSQL.setValue("model", jsonObject.getString("fmodel"));//型号
  183. updateSQL.setValue("cheek", cheek);//工艺
  184. updateSQL.setValue("itemname", jsonObject.getString("fitemname"));//品名
  185. // updateSQL.setValue("standards","");//规格
  186. updateSQL.setValue("color", color);//颜色
  187. updateSQL.setValue("batchcontrol", jsonObject.getBooleanValue("fisbatch"));//批次管理
  188. if (unitRowsMap.containsKey(jsonObject.getString("funit"))) {
  189. updateSQL.setValue("unitid", unitRowsMap.get(jsonObject.getString("funit")).get(0).getLong("unitid"));
  190. } else {
  191. updateSQL.setValue("unitid", 0);
  192. }
  193. updateSQL.setValue("spec", spec);//尺寸
  194. if(!iscustomsize){
  195. updateSQL.setValue("sa_customschemeid", 0);
  196. updateSQL.setValue("materialschemeid", 0);
  197. updateSQL.setValue("colorschemeid", 0);
  198. updateSQL.setValue("cheekschemeid", 0);
  199. updateSQL.setValue("widthschemeid", 0);
  200. updateSQL.setValue("lengthschemeid", 0);
  201. }
  202. sqlList.add(updateSQL.getSQL());
  203. UpdateSQL updateSQL2 = SQLFactory.createUpdateSQL(new DBConnect(), "plm_itemextend");
  204. updateSQL2.setWhere("itemid", itemid);
  205. updateSQL2.setSiteid(siteid);
  206. updateSQL2.setValue("material", material);//颜色
  207. sqlList.add(updateSQL2.getSQL());
  208. }
  209. }
  210. }
  211. System.err.println(sqlList);
  212. dbConnect.runSqlUpdate(sqlList);
  213. Parameter.create(new BaseClass(), paramname, simpleDateFormat.format(new Date()), "");
  214. }
  215. }
  216. public String getAutoDockItemServiceTime(String paramname, SimpleDateFormat simpleDateFormat) throws YosException {
  217. Rows rows = new DBConnect().runSqlQuery("select * from sys_parameter where paramname='" + paramname + "'");
  218. Date date = new Date();
  219. String AutoDockItemServiceTime = simpleDateFormat.format(date);
  220. if (rows.isNotEmpty()) {
  221. AutoDockItemServiceTime = rows.get(0).getString("paramvalue");
  222. dbConnect.runSqlUpdate("delete from sys_parameter where paramname='" + paramname + "'");
  223. } else {
  224. Parameter.create(new BaseClass(), paramname, simpleDateFormat.format(date), "");
  225. }
  226. return AutoDockItemServiceTime;
  227. }
  228. }