AutoDockItemService.java 19 KB

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