HaifmvSjlrDaHpController.java 58 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666
  1. package com.huimv.sjlr.plus;
  2. import java.math.BigDecimal;
  3. import java.util.ArrayList;
  4. import java.util.Arrays;
  5. import java.util.Calendar;
  6. import java.util.Collections;
  7. import java.util.Date;
  8. import java.util.GregorianCalendar;
  9. import java.util.HashMap;
  10. import java.util.List;
  11. import java.util.Map;
  12. import javax.servlet.http.HttpServletRequest;
  13. import javax.servlet.http.HttpServletResponse;
  14. import org.springframework.util.StringUtils;
  15. import org.springframework.web.servlet.ModelAndView;
  16. import com.huimv.busi.tjt.dto.HighchartsDTO;
  17. import com.huimv.busi.xt.constant.XtAppConstant;
  18. import com.huimv.busi.xt.model.CommonService;
  19. import com.huimv.busi.xt.utils.DateUtil;
  20. import com.huimv.busi.xt.utils.JsonUtil;
  21. import com.huimv.da.dao.DaMcdaDAO;
  22. import com.huimv.da.dataobject.DaMcda;
  23. import com.huimv.dto.SjlrMzxxDTO;
  24. import com.huimv.dto.SjlrMzxxxxDTO;
  25. import com.huimv.sjlr.dao.SjlrCjjlDAO;
  26. import com.huimv.sjlr.dao.SjlrDnjlDAO;
  27. import com.huimv.sjlr.dao.SjlrFmjlDAO;
  28. import com.huimv.sjlr.dao.SjlrGzdaDAO;
  29. import com.huimv.sjlr.dao.SjlrMzdaDAO;
  30. import com.huimv.sjlr.dao.SjlrPzjlDAO;
  31. import com.huimv.sjlr.dao.SjlrRsjlDAO;
  32. import com.huimv.sjlr.dao.SjlrZzttDAO;
  33. import com.huimv.sjlr.dao.SjlrZzwdDAO;
  34. import com.huimv.sjlr.dataobject.SjlrCjjl;
  35. import com.huimv.sjlr.dataobject.SjlrCjjlExample;
  36. import com.huimv.sjlr.dataobject.SjlrDnjl;
  37. import com.huimv.sjlr.dataobject.SjlrDnjlExample;
  38. import com.huimv.sjlr.dataobject.SjlrFmjl;
  39. import com.huimv.sjlr.dataobject.SjlrFmjlExample;
  40. import com.huimv.sjlr.dataobject.SjlrGzda;
  41. import com.huimv.sjlr.dataobject.SjlrGzdaExample;
  42. import com.huimv.sjlr.dataobject.SjlrMzda;
  43. import com.huimv.sjlr.dataobject.SjlrMzdaExample;
  44. import com.huimv.sjlr.dataobject.SjlrPzjl;
  45. import com.huimv.sjlr.dataobject.SjlrPzjlExample;
  46. import com.huimv.sjlr.dataobject.SjlrRsjl;
  47. import com.huimv.sjlr.dataobject.SjlrRsjlExample;
  48. import com.huimv.sjlr.dataobject.SjlrZztt;
  49. import com.huimv.sjlr.dataobject.SjlrZzttExample;
  50. import com.huimv.sjlr.dataobject.SjlrZzwd;
  51. import com.huimv.web.base.BaseController;
  52. import com.huimv.xt.dao.XtGydmDAO;
  53. import com.huimv.xt.dataobject.XtGydm;
  54. public class HaifmvSjlrDaHpController extends BaseController {
  55. private CommonService commonService;
  56. private XtGydmDAO xtGydmDAO;
  57. private SjlrGzdaDAO sjlrGzdaDAO;
  58. private DaMcdaDAO daMcdaDAO;
  59. private SjlrMzdaDAO sjlrMzdaDAO;
  60. private SjlrZzwdDAO sjlrZzwdDAO;
  61. private SjlrCjjlDAO sjlrCjjlDAO;
  62. private SjlrPzjlDAO sjlrPzjlDAO;
  63. private SjlrRsjlDAO sjlrRsjlDAO;
  64. private SjlrFmjlDAO sjlrFmjlDAO;
  65. private SjlrDnjlDAO sjlrDnjlDAO;
  66. private SjlrZzttDAO sjlrZzttDAO;
  67. /**
  68. * 加载公猪档案
  69. * @param request
  70. * @param response
  71. * @return
  72. * @throws Exception
  73. */
  74. public ModelAndView hvSjlrDaIndex(HttpServletRequest request,
  75. HttpServletResponse response) throws Exception {
  76. ModelAndView mv = new ModelAndView("haifmv/sjrl/da/gzda/gzdaIndex.htm");
  77. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  78. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_GZSXZT);//公猪筛选状态
  79. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  80. String mcid = request.getParameter("mcid");
  81. String dweb = request.getParameter("dweb");
  82. String rdqzt = request.getParameter("dqzt");
  83. String rsl = request.getParameter("sl");
  84. String dqztStr = request.getParameter("dqztArray");
  85. String slStr = request.getParameter("slArray");
  86. String ztsl = request.getParameter("ztsl");
  87. String cxeph = request.getParameter("cxeph");
  88. List<String> ztList = new ArrayList<String>();
  89. List<String> xzslList = new ArrayList<String>();
  90. if (StringUtils.hasText(ztsl)) {
  91. if (ztsl.equals("null@null")) {
  92. ztsl = "";
  93. }else {
  94. String ztslarr[] = ztsl.split("@");
  95. if (StringUtils.hasText(ztslarr[0])) {
  96. dqztStr = ztslarr[0];
  97. rdqzt = "1";
  98. }
  99. if (StringUtils.hasText(ztslarr[1])) {
  100. slStr = ztslarr[1];
  101. rsl = "1";
  102. }
  103. }
  104. }
  105. if (StringUtils.hasText(mcid)) {
  106. SjlrGzdaExample gzEx = new SjlrGzdaExample();
  107. SjlrGzdaExample.Criteria gzCr = gzEx.createCriteria();
  108. gzCr.andMcidEqualTo(Integer.parseInt(mcid)).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  109. gzCr.andLcrqIsNull();
  110. if (StringUtils.hasText(dweb)) {
  111. gzCr.andDwebLike("%" + dweb + "%");
  112. mv.addObject("dweb", dweb);
  113. }else if (StringUtils.hasText(cxeph)) {
  114. gzCr.andEphLike("%" + cxeph + "%");
  115. mv.addObject("dweb", cxeph);
  116. }
  117. if (StringUtils.hasText(rdqzt) && rdqzt.equals("1")) {
  118. String dqztArr[] = dqztStr.split(",");
  119. for (int i = 0 ; i < dqztArr.length ; i++) {
  120. if (!dqztArr[i].equals(",")) {
  121. ztList.add(dqztArr[i]);
  122. }
  123. }
  124. if (ztList.size() > 0) {
  125. gzCr.andDqztIn(ztList);
  126. }
  127. }
  128. if (StringUtils.hasText(rsl) && rsl.equals("1")) {
  129. String slArr[] = slStr.split(",");
  130. for (int i = 0 ; i < slArr.length ; i++) {
  131. if(!slArr[i].equals(",")) {
  132. xzslList.add(slArr[i]);
  133. }
  134. }
  135. if (xzslList.size() > 0) {
  136. gzCr.andSlIn(xzslList);
  137. }
  138. }
  139. gzEx.setOrderByClause("xgsj desc");
  140. int count = sjlrGzdaDAO.countByExample(gzEx);
  141. gzEx.setStart(0);
  142. gzEx.setLimit(25);
  143. List<SjlrGzda> gzdaList = sjlrGzdaDAO.selectByExample(gzEx);//首页只显示25条,其他的通过下拉进行加载
  144. int maxPages = (count % 25 == 0 ? count / 25 : count / 25 + 1);
  145. mv.addObject("maxPages",maxPages);
  146. mv.addObject("page",1);
  147. if (gzdaList != null && gzdaList.size() > 0) {
  148. for (SjlrGzda sjlrGzda : gzdaList) {
  149. //品种
  150. if (StringUtils.hasText(sjlrGzda.getQt())) {
  151. sjlrGzda.setPzStr(sjlrGzda.getQt());
  152. } else {
  153. if (StringUtils.hasText(sjlrGzda.getPz())) {
  154. for (XtGydm xtGydm : pzList) {
  155. if (sjlrGzda.getPz().equals(xtGydm.getDmid())) {
  156. sjlrGzda.setPzStr(xtGydm.getDmmc());
  157. }
  158. }
  159. }
  160. }
  161. //当前状态
  162. if (StringUtils.hasText(sjlrGzda.getDqzt())) {
  163. for (XtGydm xtGydm : dqztList) {
  164. if (sjlrGzda.getDqzt().equals(xtGydm.getDmid())) {
  165. sjlrGzda.setDqztStr(xtGydm.getDmmc());
  166. }
  167. }
  168. }
  169. }
  170. }
  171. mv.addObject("gzdaList", gzdaList);
  172. }
  173. mv.addObject("slList", slList);
  174. mv.addObject("dqztList", dqztList);
  175. mv.addObject("ztsl", dqztStr+"@"+slStr);
  176. return mv;
  177. }
  178. /**
  179. * 公猪列表下拉加载
  180. **/
  181. public void addSjlrGzda(HttpServletRequest request,
  182. HttpServletResponse response) throws Exception {
  183. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_MZZT);
  184. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  185. String mcid = request.getParameter("mcid");
  186. String page = request.getParameter("page");
  187. List<SjlrGzda> gzdaList = null;
  188. String rdqzt = request.getParameter("dqzt");
  189. String rsl = request.getParameter("sl");
  190. String dqztStr = request.getParameter("dqztArray");
  191. String slStr = request.getParameter("slArray");
  192. String ztsl = request.getParameter("ztsl");
  193. String cxeph = request.getParameter("cxeph");
  194. List<String> ztList = new ArrayList<String>();
  195. List<String> xzslList = new ArrayList<String>();
  196. //如果有ztsl 说明是删选后找到的种猪点了返回,返回到删选状态
  197. if (StringUtils.hasText(ztsl)) {
  198. if (ztsl.equals("null@null")) {
  199. ztsl = "";
  200. }else {
  201. String ztslarr[] = ztsl.split("@");
  202. if (StringUtils.hasText(ztslarr[0])) {
  203. dqztStr = ztslarr[0];
  204. rdqzt = "1";
  205. }
  206. if (StringUtils.hasText(ztslarr[1])) {
  207. slStr = ztslarr[1];
  208. rsl = "1";
  209. }
  210. }
  211. }
  212. if (StringUtils.hasText(mcid)) {
  213. SjlrGzdaExample gzEx = new SjlrGzdaExample();
  214. SjlrGzdaExample.Criteria gzCr = gzEx.createCriteria();
  215. gzCr.andMcidEqualTo(Integer.parseInt(mcid)).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  216. gzCr.andLcrqIsNull();
  217. if (StringUtils.hasText(cxeph)) {
  218. gzCr.andEphLike("%" + cxeph + "%");
  219. }
  220. if (StringUtils.hasText(rdqzt) && rdqzt.equals("1")) {
  221. String dqztArr[] = dqztStr.split(",");
  222. for (int i = 0 ; i < dqztArr.length ; i++) {
  223. if (!dqztArr[i].equals(",")) {
  224. ztList.add(dqztArr[i]);
  225. }
  226. }
  227. if (ztList.size() > 0) {
  228. gzCr.andDqztIn(ztList);
  229. }
  230. }
  231. if (StringUtils.hasText(rsl) && rsl.equals("1")) {
  232. String slArr[] = slStr.split(",");
  233. for (int i = 0 ; i < slArr.length ; i++) {
  234. if(!slArr[i].equals(",")) {
  235. xzslList.add(slArr[i]);
  236. }
  237. }
  238. if (xzslList.size() > 0) {
  239. gzCr.andSlIn(xzslList);
  240. }
  241. }
  242. gzEx.setOrderByClause("xgsj desc");
  243. gzEx.setStart((Integer.parseInt(page)-1)*25);
  244. gzEx.setLimit(25);
  245. gzdaList = sjlrGzdaDAO.selectByExample(gzEx);//一次下拉加载25条
  246. if (gzdaList != null && gzdaList.size() > 0) {
  247. for (SjlrGzda sjlrGzda : gzdaList) {
  248. //品种
  249. if (StringUtils.hasText(sjlrGzda.getQt())) {
  250. sjlrGzda.setPzStr(sjlrGzda.getQt());
  251. } else {
  252. if (StringUtils.hasText(sjlrGzda.getPz())) {
  253. for (XtGydm xtGydm : pzList) {
  254. if (sjlrGzda.getPz().equals(xtGydm.getDmid())) {
  255. sjlrGzda.setPzStr(xtGydm.getDmmc());
  256. }
  257. }
  258. }
  259. }
  260. //当前状态
  261. if (StringUtils.hasText(sjlrGzda.getDqzt())) {
  262. for (XtGydm xtGydm : dqztList) {
  263. if (sjlrGzda.getDqzt().equals(xtGydm.getDmid())) {
  264. sjlrGzda.setDqztStr(xtGydm.getDmmc());
  265. }
  266. }
  267. }
  268. }
  269. }
  270. }
  271. response.setCharacterEncoding("UTF-8");
  272. response.setContentType("text/plain; charset=UTF-8");
  273. response.addHeader("Cache-Control", "no-cache,must-revalidate");
  274. response.addHeader("Pragma", "no-cache");
  275. String param = JsonUtil.list2json(gzdaList);
  276. response.getWriter().write(param);
  277. }
  278. /**
  279. * 加载公猪档案新增页面
  280. * @param request
  281. * @param response
  282. * @return
  283. * @throws Exception
  284. */
  285. public ModelAndView hvSjlrGzdaAdd(HttpServletRequest request,
  286. HttpServletResponse response) throws Exception {
  287. ModelAndView mv = new ModelAndView("haifmv/sjrl/da/gzda/editGzda.htm");
  288. String mcid = request.getParameter("mcid");
  289. String dweb = request.getParameter("dweb");
  290. String sswd = request.getParameter("sswd");
  291. String edit = request.getParameter("edit");
  292. String newDweb = request.getParameter("newDweb");
  293. String oldDweb = request.getParameter("oldDweb");
  294. String devType = request.getParameter("devType");
  295. String p = ""; //add标题
  296. String gzwd = request.getParameter("gzwd");//标志着从首页读取温度。只能修改温度。不查重
  297. mv.addObject("oldDweb", oldDweb);
  298. int size = 0;
  299. SjlrGzda sjlrGzda = new SjlrGzda();
  300. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  301. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_GZZT);
  302. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  303. List<XtGydm> lyList = getGydm(XtAppConstant.CODE_SJLR_ZZLY);
  304. if (StringUtils.hasText(mcid)) {
  305. DaMcda daMcda = daMcdaDAO.selectByPrimaryKey(Integer.parseInt(mcid));
  306. mv.addObject("mcmc", daMcda.getMcmc());
  307. mv.addObject("mcid", mcid);
  308. if (StringUtils.hasText(dweb) || StringUtils.hasText(oldDweb)) {
  309. if (StringUtils.hasText(oldDweb)) {
  310. dweb = oldDweb;
  311. }
  312. SjlrGzdaExample gzEx = new SjlrGzdaExample();
  313. SjlrGzdaExample.Criteria gzCr = gzEx.createCriteria();
  314. gzCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  315. List<SjlrGzda> gzdaList = sjlrGzdaDAO.selectByExample(gzEx);
  316. if (gzdaList != null && gzdaList.size() > 0) {
  317. sjlrGzda = gzdaList.get(0);
  318. size = 1;
  319. }
  320. sjlrGzda.setDweb(dweb);
  321. if (StringUtils.hasText(newDweb)) {
  322. sjlrGzda.setDweb(newDweb);
  323. }
  324. mv.addObject("sswd", sswd);
  325. mv.addObject("sjlrGzda", sjlrGzda);
  326. }
  327. }
  328. if (StringUtils.hasText(gzwd) && size == 1) {
  329. edit = "notEdit"; //手持机首页添加公猪温度
  330. p = "修改实时体温";
  331. }
  332. if (StringUtils.hasText(gzwd) && size == 0) {
  333. edit = ""; //手持机首页新增公猪档案
  334. p = "新增公猪档案";
  335. }
  336. if (!StringUtils.hasText(gzwd) && size == 1 ) {
  337. p = "修改公猪档案"; //页面修改公猪档案
  338. }
  339. if (!StringUtils.hasText(gzwd) && size == 0 ) {
  340. p = "新增公猪档案"; //页面新增公猪档案
  341. }
  342. mv.addObject("slList", slList);
  343. mv.addObject("dqztList", dqztList);
  344. mv.addObject("pzList", pzList);
  345. mv.addObject("lyList", lyList);
  346. mv.addObject("edit",edit);
  347. mv.addObject("devType",devType);
  348. mv.addObject("p", p);
  349. return mv;
  350. }
  351. /**
  352. * 普通舍保存
  353. * @param request
  354. * @throws Exception
  355. */
  356. public void saveHaifmvSjlrGzda(HttpServletRequest request,
  357. HttpServletResponse response) throws Exception {
  358. response.setContentType("text/json; charset=UTF-8");
  359. response.addHeader("Cache-Control", "no-cache,must-revalidate");
  360. response.addHeader("Pragma", "no-cache");
  361. String jsonStr = "";
  362. String sswd = request.getParameter("sswd");
  363. String dweb = request.getParameter("dweb");
  364. String edit = request.getParameter("edit");
  365. String eph = request.getParameter("eph");
  366. String oldDweb = request.getParameter("oldDweb");
  367. String sl = request.getParameter("sl");
  368. String pz = request.getParameter("pz");
  369. String ly = request.getParameter("ly");
  370. int countMzda = 0;
  371. int countGzda = 0;
  372. int countGzEp = 0;
  373. int countMzEp = 0;
  374. int count = 0;
  375. boolean isDwebExsit = false;
  376. if (!StringUtils.hasText(edit)) {//如果新增的时候没有动物耳标
  377. if (!StringUtils.hasText(dweb) ) {//如果没有动物耳标,则已当前日期新建一个虚拟的动物耳标
  378. dweb = "@" + String.valueOf(new Date().getTime()) + "@";//#13位#
  379. } else {//新增的时候有动物耳标那么进行查重
  380. SjlrMzdaExample mzdaExample = new SjlrMzdaExample();
  381. SjlrMzdaExample.Criteria mzdaCr = mzdaExample.createCriteria();
  382. mzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  383. countMzda = sjlrMzdaDAO.countByExample(mzdaExample);
  384. SjlrGzdaExample gzdaExample = new SjlrGzdaExample();
  385. SjlrGzdaExample.Criteria gzdaCr = gzdaExample.createCriteria();
  386. gzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  387. countGzda = sjlrGzdaDAO.countByExample(gzdaExample);
  388. }
  389. }else {//修改的时候,如果没有动物耳标
  390. if (!StringUtils.hasText(dweb) ) {//那么提示有重复
  391. countMzda = 1;
  392. countGzda = 1;
  393. } else { //如果传进来的动物耳标不等于OldDweb 或者edit =editDwebNotEditEph .对动物耳标进行查重
  394. if (!oldDweb.equals(dweb) || edit.equals("editDwebNotEditEph")) {
  395. SjlrMzdaExample mzdaExample = new SjlrMzdaExample();
  396. SjlrMzdaExample.Criteria mzdaCr = mzdaExample.createCriteria();
  397. mzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  398. countMzda = sjlrMzdaDAO.countByExample(mzdaExample);
  399. SjlrGzdaExample gzdaExample = new SjlrGzdaExample();
  400. SjlrGzdaExample.Criteria gzdaCr = gzdaExample.createCriteria();
  401. gzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  402. countGzda = sjlrGzdaDAO.countByExample(gzdaExample);
  403. }
  404. }
  405. }
  406. SjlrGzda sjlrGzda = new SjlrGzda();
  407. sjlrGzda = (SjlrGzda) parseObjectFromRequest(request, sjlrGzda);
  408. sjlrGzda.setDweb(dweb);
  409. sjlrGzda.setEph(eph);
  410. //更新实时温度
  411. if (StringUtils.hasText(sswd)) {
  412. SjlrZzwd sjlrZzwd = new SjlrZzwd();
  413. BigDecimal bd=new BigDecimal(sswd);
  414. sjlrZzwd.setDqwd(bd);
  415. sjlrZzwd.setDweb(dweb);
  416. sjlrZzwd.setScsj(commonService.getCurrentDate());
  417. sjlrZzwdDAO.insertSelective(sjlrZzwd);
  418. }
  419. //耳牌号查重
  420. if (!StringUtils.hasText(edit)){
  421. SjlrMzdaExample mzdaEpExample = new SjlrMzdaExample();
  422. SjlrMzdaExample.Criteria mzdaepCr = mzdaEpExample.createCriteria();
  423. mzdaepCr.andEphEqualTo(sjlrGzda.getEph()).andMcidEqualTo(sjlrGzda.getMcid()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID)
  424. .andLcrqIsNull();
  425. List<SjlrMzda> mzList = sjlrMzdaDAO.selectByExample(mzdaEpExample);
  426. countMzEp = mzList.size();//有重复的且还没有离场
  427. SjlrGzdaExample gzdaEpExample = new SjlrGzdaExample();
  428. SjlrGzdaExample.Criteria gzdaEpCr = gzdaEpExample.createCriteria();
  429. gzdaEpCr.andEphEqualTo(sjlrGzda.getEph()).andMcidEqualTo(sjlrGzda.getMcid()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID)
  430. .andLcrqIsNull();
  431. List<SjlrGzda> gzList = sjlrGzdaDAO.selectByExample(gzdaEpExample);
  432. countGzEp = gzList.size();//有重复的且还没有离场
  433. }
  434. if (countMzEp > 0) {
  435. //母猪档案中已经有相同的耳牌号
  436. jsonStr = "{\"count\" : \"3\"}";
  437. }else {
  438. if(countGzEp > 0) {
  439. //公猪档案中已经有相同的耳牌号
  440. jsonStr = "{\"count\" : \"3\"}";
  441. }else {
  442. count++;
  443. }
  444. }
  445. if (countMzda > 0) {
  446. isDwebExsit = true;
  447. //母猪档案中已经有相同的耳标号
  448. jsonStr = "{\"count\" : \"0\"}";
  449. }else {
  450. if(countGzda > 0) {
  451. isDwebExsit = true;
  452. jsonStr = "{\"count\" : \"0\"}";
  453. }else {
  454. count++;
  455. }
  456. }
  457. sjlrGzda.setXgr(getLoginSessionBean(request).getYhid().toString());
  458. sjlrGzda.setXgsj(commonService.getCurrentDate());
  459. sjlrGzda.setZfbz(XtAppConstant.ZFBZ_VALID);
  460. sjlrGzda.setDweb(dweb);
  461. sjlrGzda.setSl(sl);
  462. sjlrGzda.setPz(pz);
  463. sjlrGzda.setLy(ly);
  464. if (StringUtils.hasText(edit) && !edit.equals("notEdit")) {
  465. if (!isDwebExsit) {
  466. sjlrGzdaDAO.updateByPrimaryKeySelective(sjlrGzda);
  467. jsonStr = "{\"count\" : \"2\"}";
  468. if (!oldDweb.equals(dweb)) {
  469. Map<String, Object> paramMap = new HashMap<String, Object>();
  470. paramMap.put("oldDweb", oldDweb);
  471. paramMap.put("newDweb", dweb);
  472. sjlrMzdaDAO.updateDwebAllByParam(paramMap);
  473. }
  474. }
  475. }else {
  476. if(count == 2) {
  477. if (!edit.equals("notEdit")) {
  478. sjlrGzda.setDqzt(XtAppConstant.CODE_SJLR_DQZT_HB);
  479. sjlrGzdaDAO.insertSelective(sjlrGzda);
  480. }
  481. jsonStr = "{\"count\" : \"1\"}";
  482. }
  483. }
  484. response.getWriter().write(jsonStr);
  485. }
  486. /**
  487. * 加载母猪档案
  488. * @param request
  489. * @param response
  490. * @return
  491. * @throws Exception
  492. */
  493. public ModelAndView hvSjlrMzDaIndex(HttpServletRequest request,
  494. HttpServletResponse response) throws Exception {
  495. ModelAndView mv = new ModelAndView("haifmv/sjrl/da/mzda/mzdaIndex.htm");
  496. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  497. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_MZZT);
  498. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  499. String mcid = request.getParameter("mcid");
  500. String dweb = request.getParameter("dweb");
  501. String rdqzt = request.getParameter("dqzt");
  502. String rsl = request.getParameter("sl");
  503. String dqztStr = request.getParameter("dqztArray");
  504. String slStr = request.getParameter("slArray");
  505. String ztsl = request.getParameter("ztsl");
  506. String cxeph = request.getParameter("cxeph");
  507. List<String> ztList = new ArrayList<String>();
  508. List<String> xzslList = new ArrayList<String>();
  509. //如果有ztsl 说明是删选后找到的种猪点了返回,返回到删选状态
  510. if (StringUtils.hasText(ztsl)) {
  511. if (ztsl.equals("null@null")) {
  512. ztsl = "";
  513. }else {
  514. String ztslarr[] = ztsl.split("@");
  515. if (StringUtils.hasText(ztslarr[0])) {
  516. dqztStr = ztslarr[0];
  517. rdqzt = "1";
  518. }
  519. if (StringUtils.hasText(ztslarr[1])) {
  520. slStr = ztslarr[1];
  521. rsl = "1";
  522. }
  523. }
  524. }
  525. if (StringUtils.hasText(mcid)) {
  526. SjlrMzdaExample mzEx = new SjlrMzdaExample();
  527. SjlrMzdaExample.Criteria mzCr = mzEx.createCriteria();
  528. mzCr.andMcidEqualTo(Integer.parseInt(mcid)).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  529. mzCr.andLcrqIsNull();
  530. if (StringUtils.hasText(dweb)) {
  531. mzCr.andDwebLike("%" + dweb + "%");
  532. mv.addObject("dweb", dweb);
  533. }else if (StringUtils.hasText(cxeph)) {
  534. mzCr.andEphLike("%" + cxeph + "%");
  535. mv.addObject("dweb", cxeph);
  536. }
  537. if (StringUtils.hasText(rdqzt) && rdqzt.equals("1")) {
  538. String dqztArr[] = dqztStr.split(",");
  539. for (int i = 0 ; i < dqztArr.length ; i++) {
  540. if (!dqztArr[i].equals(",")) {
  541. ztList.add(dqztArr[i]);
  542. }
  543. }
  544. if (ztList.size() > 0) {
  545. mzCr.andDqztIn(ztList);
  546. }
  547. }
  548. if (StringUtils.hasText(rsl) && rsl.equals("1")) {
  549. String slArr[] = slStr.split(",");
  550. for (int i = 0 ; i < slArr.length ; i++) {
  551. if(!slArr[i].equals(",")) {
  552. xzslList.add(slArr[i]);
  553. }
  554. }
  555. if (xzslList.size() > 0) {
  556. mzCr.andSlIn(xzslList);
  557. }
  558. }
  559. mzEx.setOrderByClause("xgsj desc");
  560. int count = sjlrMzdaDAO.countByExample(mzEx);
  561. mzEx.setStart(0);
  562. mzEx.setLimit(25);
  563. List<SjlrMzda> mzdaList = sjlrMzdaDAO.selectByExample(mzEx);//首页只显示25条,其他的通过下拉进行加载
  564. int maxPages = (count % 25 == 0 ? count / 25 : count / 25 + 1);
  565. mv.addObject("maxPages",maxPages);
  566. mv.addObject("page",1);
  567. if (mzdaList != null && mzdaList.size() > 0) {
  568. for (SjlrMzda sjlrMzda : mzdaList) {
  569. //品种
  570. if (StringUtils.hasText(sjlrMzda.getQt())) {
  571. sjlrMzda.setPzStr(sjlrMzda.getQt());
  572. } else {
  573. if (StringUtils.hasText(sjlrMzda.getPz())) {
  574. for (XtGydm xtGydm : pzList) {
  575. if (sjlrMzda.getPz().equals(xtGydm.getDmid())) {
  576. sjlrMzda.setPzStr(xtGydm.getDmmc());
  577. }
  578. }
  579. }
  580. }
  581. //当前状态
  582. if (StringUtils.hasText(sjlrMzda.getDqzt())) {
  583. for (XtGydm xtGydm : dqztList) {
  584. if (sjlrMzda.getDqzt().equals(xtGydm.getDmid())) {
  585. sjlrMzda.setDqztStr(xtGydm.getDmmc());
  586. }
  587. }
  588. }
  589. }
  590. }
  591. mv.addObject("mzdaList", mzdaList);
  592. }
  593. mv.addObject("slList", slList);
  594. mv.addObject("dqztList", dqztList);
  595. mv.addObject("ztsl", dqztStr+"@"+slStr);
  596. return mv;
  597. }
  598. /**
  599. * 母猪列表下拉加载
  600. **/
  601. public void addSjlrMzda(HttpServletRequest request,
  602. HttpServletResponse response) throws Exception {
  603. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_MZZT);
  604. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  605. String mcid = request.getParameter("mcid");
  606. String page = request.getParameter("page");
  607. List<SjlrMzda> mzdaList = null;
  608. String rdqzt = request.getParameter("dqzt");
  609. String rsl = request.getParameter("sl");
  610. String dqztStr = request.getParameter("dqztArray");
  611. String slStr = request.getParameter("slArray");
  612. String ztsl = request.getParameter("ztsl");
  613. String cxeph = request.getParameter("cxeph");
  614. List<String> ztList = new ArrayList<String>();
  615. List<String> xzslList = new ArrayList<String>();
  616. //如果有ztsl 说明是删选后找到的种猪点了返回,返回到删选状态
  617. if (StringUtils.hasText(ztsl)) {
  618. if (ztsl.equals("null@null")) {
  619. ztsl = "";
  620. }else {
  621. String ztslarr[] = ztsl.split("@");
  622. if (StringUtils.hasText(ztslarr[0])) {
  623. dqztStr = ztslarr[0];
  624. rdqzt = "1";
  625. }
  626. if (StringUtils.hasText(ztslarr[1])) {
  627. slStr = ztslarr[1];
  628. rsl = "1";
  629. }
  630. }
  631. }
  632. if (StringUtils.hasText(mcid)) {
  633. SjlrMzdaExample mzEx = new SjlrMzdaExample();
  634. SjlrMzdaExample.Criteria mzCr = mzEx.createCriteria();
  635. mzCr.andMcidEqualTo(Integer.parseInt(mcid)).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  636. mzCr.andLcrqIsNull();
  637. if (StringUtils.hasText(cxeph)) {
  638. mzCr.andEphLike("%" + cxeph + "%");
  639. }
  640. if (StringUtils.hasText(rdqzt) && rdqzt.equals("1")) {
  641. String dqztArr[] = dqztStr.split(",");
  642. for (int i = 0 ; i < dqztArr.length ; i++) {
  643. if (!dqztArr[i].equals(",")) {
  644. ztList.add(dqztArr[i]);
  645. }
  646. }
  647. if (ztList.size() > 0) {
  648. mzCr.andDqztIn(ztList);
  649. }
  650. }
  651. if (StringUtils.hasText(rsl) && rsl.equals("1")) {
  652. String slArr[] = slStr.split(",");
  653. for (int i = 0 ; i < slArr.length ; i++) {
  654. if(!slArr[i].equals(",")) {
  655. xzslList.add(slArr[i]);
  656. }
  657. }
  658. if (xzslList.size() > 0) {
  659. mzCr.andSlIn(xzslList);
  660. }
  661. }
  662. mzEx.setOrderByClause("xgsj desc");
  663. mzEx.setStart((Integer.parseInt(page)-1)*25);
  664. mzEx.setLimit(25);
  665. mzdaList = sjlrMzdaDAO.selectByExample(mzEx);//一次下拉加载25条
  666. if (mzdaList != null && mzdaList.size() > 0) {
  667. for (SjlrMzda sjlrMzda : mzdaList) {
  668. //品种
  669. if (StringUtils.hasText(sjlrMzda.getQt())) {
  670. sjlrMzda.setPzStr(sjlrMzda.getQt());
  671. } else {
  672. if (StringUtils.hasText(sjlrMzda.getPz())) {
  673. for (XtGydm xtGydm : pzList) {
  674. if (sjlrMzda.getPz().equals(xtGydm.getDmid())) {
  675. sjlrMzda.setPzStr(xtGydm.getDmmc());
  676. }
  677. }
  678. }
  679. }
  680. //当前状态
  681. if (StringUtils.hasText(sjlrMzda.getDqzt())) {
  682. for (XtGydm xtGydm : dqztList) {
  683. if (sjlrMzda.getDqzt().equals(xtGydm.getDmid())) {
  684. sjlrMzda.setDqztStr(xtGydm.getDmmc());
  685. }
  686. }
  687. }
  688. }
  689. }
  690. }
  691. response.setCharacterEncoding("UTF-8");
  692. response.setContentType("text/plain; charset=UTF-8");
  693. response.addHeader("Cache-Control", "no-cache,must-revalidate");
  694. response.addHeader("Pragma", "no-cache");
  695. String param = JsonUtil.list2json(mzdaList);
  696. response.getWriter().write(param);
  697. }
  698. /**
  699. * 四舍五入
  700. * @param v
  701. * @param scale 保留小数位数
  702. * @return
  703. */
  704. public String round(double v, int scale) {
  705. if (scale < 0) {
  706. throw new IllegalArgumentException("The scale must be a positive integer or zero");
  707. }
  708. BigDecimal b = new BigDecimal(Double.toString(v));
  709. BigDecimal one = new BigDecimal("1");
  710. return String.valueOf(b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue());
  711. }
  712. /**
  713. * 加载母猪档案新增页面
  714. * @param request
  715. * @param response
  716. * @return
  717. * @throws Exception
  718. */
  719. public ModelAndView hvSjlrMzdaAdd(HttpServletRequest request,
  720. HttpServletResponse response) throws Exception {
  721. ModelAndView mv = new ModelAndView("haifmv/sjrl/da/mzda/editMzda.htm");
  722. String mcid = request.getParameter("mcid");
  723. String dweb = request.getParameter("dweb");
  724. String sswd = request.getParameter("sswd");
  725. String edit = request.getParameter("edit");
  726. String newDweb = request.getParameter("newDweb");
  727. String oldDweb = request.getParameter("oldDweb");
  728. mv.addObject("oldDweb", oldDweb);
  729. int size = 0;
  730. String p = ""; //add页面标题
  731. String mzwd = request.getParameter("mzwd");//标志着从首页读取温度。只能修改温度。不查重
  732. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  733. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_MZZT);
  734. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  735. List<XtGydm> lyList = getGydm(XtAppConstant.CODE_SJLR_ZZLY);
  736. SjlrMzda sjlrMzda = new SjlrMzda();
  737. if (StringUtils.hasText(mcid)) {
  738. DaMcda daMcda = daMcdaDAO.selectByPrimaryKey(Integer.parseInt(mcid));
  739. mv.addObject("mcmc", daMcda.getMcmc());
  740. mv.addObject("mcid", mcid);
  741. if (StringUtils.hasText(dweb) || StringUtils.hasText(oldDweb)) {
  742. if (StringUtils.hasText(oldDweb)) {
  743. dweb = oldDweb;
  744. }
  745. SjlrMzdaExample mzEx = new SjlrMzdaExample();
  746. SjlrMzdaExample.Criteria mzCr = mzEx.createCriteria();
  747. mzCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  748. List<SjlrMzda> mzdaList = sjlrMzdaDAO.selectByExample(mzEx);
  749. if (mzdaList != null && mzdaList.size() > 0) {
  750. sjlrMzda = mzdaList.get(0);
  751. size = 1;
  752. }
  753. sjlrMzda.setDweb(dweb);
  754. if (StringUtils.hasText(newDweb)) {
  755. sjlrMzda.setDweb(newDweb);
  756. }
  757. mv.addObject("sswd", sswd);
  758. }
  759. if (StringUtils.hasText(mzwd) && size == 1) {
  760. edit = "notEdit"; //手持机首页添加母猪温度
  761. p = "修改实时体温";
  762. }
  763. if (StringUtils.hasText(mzwd) && size == 0) {
  764. edit = ""; //手持机首页新增母猪档案
  765. p = "新增母猪档案";
  766. }
  767. if (!StringUtils.hasText(mzwd) && size == 1 ) {
  768. p = "修改母猪档案"; //页面修改母猪档案
  769. }
  770. if (!StringUtils.hasText(mzwd) && size == 0 ) {
  771. p = "新增母猪档案"; //页面新增母猪档案
  772. }
  773. }
  774. mv.addObject("slList", slList);
  775. mv.addObject("dqztList", dqztList);
  776. mv.addObject("pzList", pzList);
  777. mv.addObject("lyList", lyList);
  778. mv.addObject("edit",edit);
  779. mv.addObject("p", p);
  780. mv.addObject("sjlrMzda", sjlrMzda);
  781. return mv;
  782. }
  783. /**
  784. * 保存母猪档案
  785. * @param request
  786. * @throws Exception
  787. */
  788. public void saveHaifmvSjlrMzda(HttpServletRequest request,
  789. HttpServletResponse response) throws Exception {
  790. response.setContentType("text/json; charset=UTF-8");
  791. response.addHeader("Cache-Control", "no-cache,must-revalidate");
  792. response.addHeader("Pragma", "no-cache");
  793. String jsonStr = "";
  794. String sswd = request.getParameter("sswd");
  795. String dweb = request.getParameter("dweb");
  796. String edit = request.getParameter("edit");
  797. String eph = request.getParameter("eph");
  798. String oldDweb = request.getParameter("oldDweb");
  799. String sl = request.getParameter("sl");
  800. String pz = request.getParameter("pz");
  801. String ly = request.getParameter("ly");
  802. int countMzda = 0;
  803. int countGzda = 0;
  804. int countGzEp = 0;
  805. int countMzEp = 0;
  806. int count = 0;
  807. boolean isDwebExsit = false;
  808. if (!StringUtils.hasText(edit)) {//如果新增的时候没有动物耳标
  809. if (!StringUtils.hasText(dweb) ) {//如果没有动物耳标,则已当前日期新建一个虚拟的动物耳标
  810. dweb = "@" + String.valueOf(new Date().getTime()) + "@";//#13位#
  811. } else {//新增的时候有动物耳标那么进行查重
  812. SjlrMzdaExample mzdaExample = new SjlrMzdaExample();
  813. SjlrMzdaExample.Criteria mzdaCr = mzdaExample.createCriteria();
  814. mzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  815. countMzda = sjlrMzdaDAO.countByExample(mzdaExample);
  816. SjlrGzdaExample gzdaExample = new SjlrGzdaExample();
  817. SjlrGzdaExample.Criteria gzdaCr = gzdaExample.createCriteria();
  818. gzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  819. countGzda = sjlrGzdaDAO.countByExample(gzdaExample);
  820. }
  821. }else {//修改的时候,如果没有动物耳标
  822. if (!StringUtils.hasText(dweb) ) {//那么提示有重复
  823. countMzda = 1;
  824. countGzda = 1;
  825. } else { //如果有动物耳标 那么进行查重
  826. if (!oldDweb.equals(dweb) || edit.equals("editDwebNotEditEph")) {
  827. //如果新旧耳标不相等或者从edit页面进入edit页面 表示修改耳标号 需要查重耳标
  828. SjlrMzdaExample mzdaExample = new SjlrMzdaExample();
  829. SjlrMzdaExample.Criteria mzdaCr = mzdaExample.createCriteria();
  830. mzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  831. countMzda = sjlrMzdaDAO.countByExample(mzdaExample);
  832. SjlrGzdaExample gzdaExample = new SjlrGzdaExample();
  833. SjlrGzdaExample.Criteria gzdaCr = gzdaExample.createCriteria();
  834. gzdaCr.andDwebEqualTo(dweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  835. countGzda = sjlrGzdaDAO.countByExample(gzdaExample);
  836. }
  837. }
  838. }
  839. SjlrMzda sjlrMzda = new SjlrMzda();
  840. sjlrMzda = (SjlrMzda) parseObjectFromRequest(request, sjlrMzda);
  841. sjlrMzda.setDweb(dweb);
  842. sjlrMzda.setEph(eph);
  843. //更新实时温度
  844. if (StringUtils.hasText(sswd)) {
  845. SjlrZzwd sjlrZzwd = new SjlrZzwd();
  846. BigDecimal bd=new BigDecimal(sswd);
  847. sjlrZzwd.setDqwd(bd);
  848. sjlrZzwd.setDweb(dweb);
  849. sjlrZzwd.setScsj(commonService.getCurrentDate());
  850. sjlrZzwdDAO.insertSelective(sjlrZzwd);
  851. }
  852. //耳牌号查重
  853. if (!StringUtils.hasText(edit)){
  854. SjlrMzdaExample mzdaEpExample = new SjlrMzdaExample();
  855. SjlrMzdaExample.Criteria mzdaepCr = mzdaEpExample.createCriteria();
  856. mzdaepCr.andEphEqualTo(sjlrMzda.getEph()).andMcidEqualTo(sjlrMzda.getMcid()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  857. List<SjlrMzda> mzList = sjlrMzdaDAO.selectByExample(mzdaEpExample);
  858. if (mzList.size() > 0) {//有重复的
  859. if (mzList.get(mzList.size() - 1).getLcrq() == null) {//取当前耳牌的最后一个,判断离栏日期是否为空
  860. //如果最后一条的离栏日期位为空,则标识当前耳牌已经用过,但是猪已经离场,可以重复使用
  861. //如果最后一条的离栏日期不为空,则标识当前耳牌已经用过,但是猪还在场,不能再次使用
  862. countMzEp = mzList.size();
  863. }
  864. }
  865. SjlrGzdaExample gzdaEpExample = new SjlrGzdaExample();
  866. SjlrGzdaExample.Criteria gzdaEpCr = gzdaEpExample.createCriteria();
  867. gzdaEpCr.andEphEqualTo(sjlrMzda.getEph()).andMcidEqualTo(sjlrMzda.getMcid()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  868. List<SjlrGzda> gzList = sjlrGzdaDAO.selectByExample(gzdaEpExample);
  869. if (gzList.size() > 0) {//有重复的
  870. if (gzList.get(gzList.size() - 1).getLcrq() == null) {//取当前耳牌的最后一个,判断离栏日期是否为空
  871. //如果最后一条的离栏日期位为空,则标识当前耳牌已经用过,但是猪已经离场,可以重复使用
  872. //如果最后一条的离栏日期不为空,则标识当前耳牌已经用过,但是猪还在场,不能再次使用
  873. countGzEp = gzList.size();
  874. }
  875. }
  876. }
  877. if (countMzEp > 0) {
  878. //母猪档案中已经有相同的耳牌号
  879. jsonStr = "{\"count\" : \"3\"}";
  880. }else {
  881. if(countGzEp > 0) {
  882. //公猪档案中已经有相同的耳牌号
  883. jsonStr = "{\"count\" : \"3\"}";
  884. }else {
  885. count++;
  886. }
  887. }
  888. if (countMzda > 0) {
  889. isDwebExsit = true;
  890. //母猪档案中已经有相同的耳标号
  891. jsonStr = "{\"count\" : \"0\"}";
  892. }else {
  893. if(countGzda > 0) {
  894. isDwebExsit = true;
  895. jsonStr = "{\"count\" : \"0\"}";
  896. }else {
  897. count++;
  898. }
  899. }
  900. sjlrMzda.setXgr(getLoginSessionBean(request).getYhid().toString());
  901. sjlrMzda.setXgsj(commonService.getCurrentDate());
  902. sjlrMzda.setZfbz(XtAppConstant.ZFBZ_VALID);
  903. sjlrMzda.setDweb(dweb);
  904. sjlrMzda.setSl(sl);
  905. sjlrMzda.setPz(pz);
  906. sjlrMzda.setLy(ly);
  907. if (StringUtils.hasText(edit) && !edit.equals("notEdit")) {
  908. if (!isDwebExsit) {
  909. sjlrMzdaDAO.updateByPrimaryKeySelective(sjlrMzda);
  910. if (!oldDweb.equals(dweb)) {
  911. Map<String, Object> paramMap = new HashMap<String, Object>();
  912. paramMap.put("oldDweb", oldDweb);
  913. paramMap.put("newDweb", dweb);
  914. sjlrMzdaDAO.updateDwebAllByParam(paramMap);
  915. }
  916. jsonStr = "{\"count\" : \"2\"}";
  917. }
  918. }else {
  919. if(count == 2) {
  920. if (!edit.equals("notEdit")) {
  921. sjlrMzda.setDqzt(XtAppConstant.CODE_SJLR_DQZT_HB);
  922. sjlrMzdaDAO.insertSelective(sjlrMzda);
  923. }
  924. jsonStr = "{\"count\" : \"1\"}";
  925. }
  926. }
  927. response.getWriter().write(jsonStr);
  928. }
  929. /**
  930. * 加载公猪详细信息查看
  931. * @param request
  932. * @param response
  933. * @return
  934. * @throws Exception
  935. */
  936. public ModelAndView hvSjlrGzxx(HttpServletRequest request,
  937. HttpServletResponse response) throws Exception {
  938. ModelAndView mv = new ModelAndView("haifmv/sjrl/da/gzda/gzdaDetails.htm");
  939. String id = request.getParameter("id");
  940. String ztsl = request.getParameter("ztsl");
  941. String edit = request.getParameter("edit");
  942. String from = request.getParameter("from");
  943. if (StringUtils.hasText(id)) {
  944. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  945. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_DQZT);
  946. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  947. List<XtGydm> sfhgList = getGydm(XtAppConstant.CODE_SFHG);
  948. List<XtGydm> pzsmList = getGydm(XtAppConstant.CODE_SJLR_PZSM);
  949. SjlrGzda sjlrGzda = sjlrGzdaDAO.selectByPrimaryKey(Integer.parseInt(id));
  950. //舍栏
  951. if (StringUtils.hasText(sjlrGzda.getSl())) {
  952. for (XtGydm xtGydm : slList) {
  953. if (sjlrGzda.getSl().equals(xtGydm.getDmid())) {
  954. sjlrGzda.setSlStr(xtGydm.getDmmc());
  955. }
  956. }
  957. }
  958. //品种
  959. if (StringUtils.hasText(sjlrGzda.getQt())) {
  960. sjlrGzda.setPzStr(sjlrGzda.getQt());
  961. } else {
  962. if (StringUtils.hasText(sjlrGzda.getPz())) {
  963. for (XtGydm xtGydm : pzList) {
  964. if (sjlrGzda.getPz().equals(xtGydm.getDmid())) {
  965. sjlrGzda.setPzStr(xtGydm.getDmmc());
  966. }
  967. }
  968. }
  969. }
  970. //当前状态
  971. if (StringUtils.hasText(sjlrGzda.getDqzt())) {
  972. for (XtGydm xtGydm : dqztList) {
  973. if (sjlrGzda.getDqzt().equals(xtGydm.getDmid())) {
  974. sjlrGzda.setDqztStr(xtGydm.getDmmc());
  975. }
  976. }
  977. }
  978. mv.addObject("sjlrGzda", sjlrGzda);
  979. //采精次数 合格次数 不合格次数
  980. SjlrCjjlExample cjEx1 = new SjlrCjjlExample();
  981. SjlrCjjlExample.Criteria cjCr1 = cjEx1.createCriteria();
  982. cjCr1.andDwebEqualTo(sjlrGzda.getDweb()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  983. int cjcount = sjlrCjjlDAO.countByExample(cjEx1);
  984. cjCr1.andSfhgEqualTo(Integer.parseInt(XtAppConstant.SFHG_HG));
  985. int hgcount = sjlrCjjlDAO.countByExample(cjEx1);
  986. mv.addObject("cjcount", cjcount);
  987. mv.addObject("cjhgcount", hgcount);
  988. mv.addObject("cjbhgcount", cjcount - hgcount);
  989. //使用天数
  990. long day = (commonService.getCurrentDate().getTime() - sjlrGzda.getCsrq().getTime()) / DateUtil.MILLSECOND_OF_DAY;
  991. mv.addObject("syts", day);
  992. //配种次数
  993. Map<String, Object> paramMap = new HashMap<String, Object>();
  994. paramMap.put("gzeb", sjlrGzda.getDweb());
  995. int pzcount = sjlrPzjlDAO.countPzjlByParam(paramMap);
  996. mv.addObject("pzcount", pzcount);
  997. //配种分娩次数
  998. int pzfmcount = sjlrPzjlDAO.countPzFmByParam(paramMap);
  999. mv.addObject("pzfmcount", pzfmcount);
  1000. mv.addObject("pzfml", pzcount == 0 ? 0 : Math.round(pzfmcount * 100 / pzcount));
  1001. //采精
  1002. SjlrCjjlExample cjEx = new SjlrCjjlExample();
  1003. SjlrCjjlExample.Criteria cjCr = cjEx.createCriteria();
  1004. cjCr.andDwebEqualTo(sjlrGzda.getDweb()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1005. cjEx.setOrderByClause("cjsj desc");
  1006. cjEx.setStart(0);
  1007. cjEx.setLimit(10);
  1008. List<SjlrCjjl> cjjlList = sjlrCjjlDAO.selectByExample(cjEx);
  1009. for (SjlrCjjl sjlrCjjl : cjjlList) {
  1010. //是否合格
  1011. if (sjlrCjjl.getSfhg() != null) {
  1012. for (XtGydm xtGydm : sfhgList) {
  1013. if (xtGydm.getDmid().equals(String.valueOf(sjlrCjjl.getSfhg()))) {
  1014. sjlrCjjl.setSfhgStr(xtGydm.getDmmc());
  1015. }
  1016. }
  1017. }
  1018. }
  1019. mv.addObject("cjjlList", cjjlList);
  1020. //配种
  1021. paramMap.put("limit", "limit 0, 10");
  1022. paramMap.put("order", "order by pz.pzsj desc");
  1023. List<SjlrPzjl> pzjlList = sjlrPzjlDAO.selectPzjlListByParam(paramMap);
  1024. for (SjlrPzjl sjlrPzjl : pzjlList) {
  1025. if (StringUtils.hasText(sjlrPzjl.getMzeb())) {
  1026. SjlrMzdaExample mzEx = new SjlrMzdaExample();
  1027. SjlrMzdaExample.Criteria mzCr = mzEx.createCriteria();
  1028. mzCr.andDwebEqualTo(sjlrPzjl.getMzeb()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1029. List<SjlrMzda> mzList = sjlrMzdaDAO.selectByExample(mzEx);
  1030. if (mzList.size() > 0) {
  1031. sjlrPzjl.setMzeb(mzList.get(0).getEph());//一配耳牌
  1032. }
  1033. }
  1034. //配种说明
  1035. if (sjlrPzjl.getPzsm() != null) {
  1036. for (XtGydm xtGydm : pzsmList) {
  1037. if (xtGydm.getDmid().equals(String.valueOf(sjlrPzjl.getPzsm()))) {
  1038. sjlrPzjl.setPzsmStr(xtGydm.getDmmc());
  1039. }
  1040. }
  1041. if (sjlrPzjl.getYpgzeb() != null && sjlrPzjl.getYpgzeb().equals(sjlrGzda.getDweb())) {
  1042. sjlrPzjl.setPzfs("首配");
  1043. sjlrPzjl.setPzfspf(sjlrPzjl.getYppf());
  1044. }
  1045. if (sjlrPzjl.getEpgzeb() != null && sjlrPzjl.getEpgzeb().equals(sjlrGzda.getDweb())) {
  1046. sjlrPzjl.setPzfs("二配");
  1047. sjlrPzjl.setPzfspf(sjlrPzjl.getEppf());
  1048. }
  1049. if (sjlrPzjl.getSpgzeb() != null && sjlrPzjl.getSpgzeb().equals(sjlrGzda.getDweb())) {
  1050. sjlrPzjl.setPzfs("三配");
  1051. sjlrPzjl.setPzfspf(sjlrPzjl.getSppf());
  1052. }
  1053. }
  1054. }
  1055. mv.addObject("pzjlList", pzjlList);
  1056. }
  1057. mv.addObject("ztsl",ztsl);
  1058. mv.addObject("edit",edit);
  1059. mv.addObject("from",from);
  1060. mv.addObject("cxeph",request.getParameter("cxeph"));
  1061. return mv;
  1062. }
  1063. /**
  1064. * 加载母猪详细信息查看
  1065. * @param request
  1066. * @param response
  1067. * @return
  1068. * @throws Exception
  1069. */
  1070. public ModelAndView hvSjlrMzxx(HttpServletRequest request,
  1071. HttpServletResponse response) throws Exception {
  1072. ModelAndView mv = new ModelAndView("haifmv/sjrl/da/mzda/daDetails.htm");
  1073. String id = request.getParameter("id");
  1074. String ztsl = request.getParameter("ztsl");
  1075. String edit = request.getParameter("edit");
  1076. String from = request.getParameter("from");
  1077. if (StringUtils.hasText(id)) {
  1078. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  1079. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_DQZT);
  1080. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  1081. List<XtGydm> pzsmList = getGydm(XtAppConstant.CODE_SJLR_PZSM);
  1082. List<XtGydm> rsJgList = getGydm(XtAppConstant.CODE_SJLR_RSJG);//妊娠结果
  1083. SjlrMzda sjlrMzda = sjlrMzdaDAO.selectByPrimaryKey(Integer.parseInt(id));
  1084. //日龄
  1085. Date csrq = sjlrMzda.getCsrq();
  1086. int rl = (int)DateUtil.getDaysBetweenDateWithoutTime(csrq, new Date());
  1087. sjlrMzda.setRl(String.valueOf(rl));
  1088. //舍栏
  1089. if (StringUtils.hasText(sjlrMzda.getSl())) {
  1090. for (XtGydm xtGydm : slList) {
  1091. if (sjlrMzda.getSl().equals(xtGydm.getDmid())) {
  1092. sjlrMzda.setSlStr(xtGydm.getDmmc());
  1093. }
  1094. }
  1095. }
  1096. //品种
  1097. if (StringUtils.hasText(sjlrMzda.getQt())) {
  1098. sjlrMzda.setPzStr(sjlrMzda.getQt());
  1099. } else {
  1100. if (StringUtils.hasText(sjlrMzda.getPz())) {
  1101. for (XtGydm xtGydm : pzList) {
  1102. if (sjlrMzda.getPz().equals(xtGydm.getDmid())) {
  1103. sjlrMzda.setPzStr(xtGydm.getDmmc());
  1104. }
  1105. }
  1106. }
  1107. }
  1108. //当前状态
  1109. if (StringUtils.hasText(sjlrMzda.getDqzt())) {
  1110. for (XtGydm xtGydm : dqztList) {
  1111. if (sjlrMzda.getDqzt().equals(xtGydm.getDmid())) {
  1112. sjlrMzda.setDqztStr(xtGydm.getDmmc());
  1113. }
  1114. }
  1115. }
  1116. int yctc = 0;//已产胎次
  1117. int hz = 0;//活仔
  1118. int wjdnts = 0;//窝均断奶头数
  1119. int ws = 0;//窝数
  1120. Map<String, Object> paramMap = new HashMap<String, Object>();
  1121. paramMap.put("dweb", sjlrMzda.getDweb());
  1122. List<SjlrMzxxxxDTO> mzxxxxList = sjlrMzdaDAO.getMzxxListByParam(paramMap);
  1123. List<SjlrMzxxDTO> mzxxList = new ArrayList<SjlrMzxxDTO>();
  1124. //List<SjlrPzjl> pzs = new ArrayList<SjlrPzjl>();
  1125. int i = 1;
  1126. for (SjlrMzxxxxDTO sjlrMzxxxxDTO : mzxxxxList) {
  1127. SjlrMzxxDTO mzxxDTO = new SjlrMzxxDTO();
  1128. SjlrPzjl sjlrPzjl = new SjlrPzjl();
  1129. sjlrPzjl.setPzsj(sjlrMzxxxxDTO.getPzsj());
  1130. sjlrPzjl.setPzsm(sjlrMzxxxxDTO.getPzsm());//配种说明
  1131. for (XtGydm xtGydm : pzsmList) {
  1132. if (xtGydm.getDmid().equals(String.valueOf(sjlrPzjl.getPzsm()))) {
  1133. sjlrPzjl.setPzsmStr(xtGydm.getDmmc());
  1134. }
  1135. }
  1136. if (StringUtils.hasText(sjlrMzxxxxDTO.getYpgzeb())) {
  1137. SjlrGzdaExample gzEx = new SjlrGzdaExample();
  1138. SjlrGzdaExample.Criteria gzCr = gzEx.createCriteria();
  1139. gzCr.andDwebEqualTo(sjlrMzxxxxDTO.getYpgzeb()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1140. List<SjlrGzda> gzList = sjlrGzdaDAO.selectByExample(gzEx);
  1141. if (gzList.size() > 0) {
  1142. sjlrPzjl.setYpgzeb(gzList.get(0).getEph());//一配耳牌
  1143. }
  1144. } else {
  1145. sjlrPzjl.setYpgzeb("未记录");
  1146. }
  1147. sjlrPzjl.setYppf(sjlrMzxxxxDTO.getYppf());//一配评分
  1148. sjlrPzjl.setFqjg(Integer.parseInt(sjlrMzxxxxDTO.getFqjg()));//发情间隔
  1149. Calendar calendar = new GregorianCalendar();
  1150. calendar.setTime(sjlrMzxxxxDTO.getPzsj());
  1151. calendar.add(Calendar.DATE, + 114);
  1152. sjlrPzjl.setYcrq(calendar.getTime());//预产日期
  1153. mzxxDTO.setSjlrPzjl(sjlrPzjl);
  1154. //妊娠数据,妊娠与配种必定是有的 ,sql决定
  1155. SjlrRsjl sjlrRsjl = new SjlrRsjl();
  1156. sjlrRsjl.setRssj(sjlrMzxxxxDTO.getRssj());
  1157. //舍栏
  1158. if (StringUtils.hasText(sjlrMzxxxxDTO.getRsjg())) {
  1159. for (XtGydm xtGydm : rsJgList) {
  1160. if (sjlrMzxxxxDTO.getRsjg().equals(xtGydm.getDmid())) {
  1161. sjlrRsjl.setRsjgStr(xtGydm.getDmmc());
  1162. }
  1163. }
  1164. }
  1165. mzxxDTO.setSjlrRsjl(sjlrRsjl);
  1166. if (StringUtils.hasText(sjlrMzxxxxDTO.getRsid())) {//分娩
  1167. SjlrFmjl sjlrFmjl = new SjlrFmjl();
  1168. sjlrFmjl.setRsid(Integer.parseInt(sjlrMzxxxxDTO.getRsid()));
  1169. sjlrFmjl.setFmsj(sjlrMzxxxxDTO.getFmsj());
  1170. int jzgs = !StringUtils.hasText(sjlrMzxxxxDTO.getJzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getJzgs());
  1171. sjlrFmjl.setJzgs(jzgs);
  1172. int rzgs = !StringUtils.hasText(sjlrMzxxxxDTO.getRzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getRzgs());
  1173. sjlrFmjl.setRzgs(rzgs);
  1174. int jxgs = !StringUtils.hasText(sjlrMzxxxxDTO.getJxgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getJxgs());
  1175. sjlrFmjl.setJxgs(jxgs);
  1176. int mnygs = !StringUtils.hasText(sjlrMzxxxxDTO.getMnygs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getMnygs());
  1177. sjlrFmjl.setMnygs(mnygs);
  1178. int stgs = !StringUtils.hasText(sjlrMzxxxxDTO.getStgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getStgs());
  1179. sjlrFmjl.setStgs(stgs);
  1180. sjlrFmjl.setHzgs(String.valueOf(jzgs + rzgs + jxgs));
  1181. sjlrFmjl.setSzgs(String.valueOf(jzgs + rzgs + jxgs + mnygs + stgs));
  1182. sjlrFmjl.setGzgs(!StringUtils.hasText(sjlrMzxxxxDTO.getGzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getGzgs()));
  1183. sjlrFmjl.setMzgs(!StringUtils.hasText(sjlrMzxxxxDTO.getMzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getMzgs()));
  1184. ws++;
  1185. hz = hz + jzgs + rzgs + jxgs;//活仔
  1186. yctc++;//已产胎次
  1187. mzxxDTO.setSjlrFmjl(sjlrFmjl);
  1188. if (StringUtils.hasText(sjlrMzxxxxDTO.getFmid())) {//断奶
  1189. SjlrDnjl sjlrDnjl = new SjlrDnjl();
  1190. sjlrDnjl.setFmid(Integer.parseInt(sjlrMzxxxxDTO.getFmid()));
  1191. sjlrDnjl.setDnsj(sjlrMzxxxxDTO.getDnsj());
  1192. int dnsl = !StringUtils.hasText(sjlrMzxxxxDTO.getZzzs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getZzzs());
  1193. sjlrDnjl.setDnsl(String.valueOf(dnsl));
  1194. sjlrDnjl.setDnwz(!StringUtils.hasText(sjlrMzxxxxDTO.getDnwz()) ? "0" : sjlrMzxxxxDTO.getDnwz());
  1195. mzxxDTO.setSjlrDnjl(sjlrDnjl);
  1196. wjdnts = wjdnts + dnsl;
  1197. }
  1198. }
  1199. mzxxDTO.setHh(String.valueOf(i));
  1200. i++;
  1201. mzxxList.add(mzxxDTO);
  1202. }
  1203. Collections.reverse(mzxxList);
  1204. sjlrMzda.setYctc(String.valueOf(yctc));
  1205. sjlrMzda.setWjhz(ws == 0 ? "0" : String.valueOf(hz / ws));
  1206. sjlrMzda.setWjdn(yctc == 0 ? "0" : String.valueOf(wjdnts / yctc));
  1207. mv.addObject("sjlrMzda", sjlrMzda);
  1208. mv.addObject("mzxxList", mzxxList);
  1209. }
  1210. mv.addObject("ztsl",ztsl);
  1211. mv.addObject("edit",edit);
  1212. mv.addObject("from",from);
  1213. mv.addObject("cxeph",request.getParameter("cxeph"));
  1214. return mv;
  1215. }
  1216. /**
  1217. * 加载淘汰母猪详细信息查看
  1218. * @param request
  1219. * @param response
  1220. * @return
  1221. * @throws Exception
  1222. */
  1223. public ModelAndView hvSjlrTtMzxx(HttpServletRequest request,
  1224. HttpServletResponse response) throws Exception {
  1225. ModelAndView mv = new ModelAndView("haifmp/sjlr/da/hpSjlrMzxx.htm");
  1226. String id = request.getParameter("id");
  1227. String ztsl = request.getParameter("ztsl");
  1228. String edit = request.getParameter("edit");
  1229. String from = request.getParameter("from");
  1230. if (StringUtils.hasText(id)) {
  1231. List<XtGydm> slList = getGydm(XtAppConstant.CODE_SJLR_SL);
  1232. List<XtGydm> dqztList = getGydm(XtAppConstant.CODE_SJLR_DQZT);
  1233. List<XtGydm> pzList = getGydm(XtAppConstant.CODE_SJLR_ZZPZ);
  1234. List<XtGydm> pzsmList = getGydm(XtAppConstant.CODE_SJLR_PZSM);
  1235. List<XtGydm> rsJgList = getGydm(XtAppConstant.CODE_SJLR_RSJG);//妊娠结果
  1236. SjlrMzda sjlrMzda = sjlrMzdaDAO.selectByPrimaryKey(Integer.parseInt(id));
  1237. //日龄
  1238. Date csrq = sjlrMzda.getCsrq();
  1239. int rl = (int)DateUtil.getDaysBetweenDateWithoutTime(csrq, new Date());
  1240. sjlrMzda.setRl(String.valueOf(rl));
  1241. //舍栏
  1242. if (StringUtils.hasText(sjlrMzda.getSl())) {
  1243. for (XtGydm xtGydm : slList) {
  1244. if (sjlrMzda.getSl().equals(xtGydm.getDmid())) {
  1245. sjlrMzda.setSlStr(xtGydm.getDmmc());
  1246. }
  1247. }
  1248. }
  1249. //品种
  1250. if (StringUtils.hasText(sjlrMzda.getQt())) {
  1251. sjlrMzda.setPzStr(sjlrMzda.getQt());
  1252. } else {
  1253. if (StringUtils.hasText(sjlrMzda.getPz())) {
  1254. for (XtGydm xtGydm : pzList) {
  1255. if (sjlrMzda.getPz().equals(xtGydm.getDmid())) {
  1256. sjlrMzda.setPzStr(xtGydm.getDmmc());
  1257. }
  1258. }
  1259. }
  1260. }
  1261. //当前状态
  1262. if (StringUtils.hasText(sjlrMzda.getDqzt())) {
  1263. for (XtGydm xtGydm : dqztList) {
  1264. if (sjlrMzda.getDqzt().equals(xtGydm.getDmid())) {
  1265. sjlrMzda.setDqztStr(xtGydm.getDmmc());
  1266. }
  1267. }
  1268. }
  1269. int yctc = 0;//已产胎次
  1270. int hz = 0;//活仔
  1271. int wjdnts = 0;//窝均断奶头数
  1272. int ws = 0;//窝数
  1273. Map<String, Object> paramMap = new HashMap<String, Object>();
  1274. paramMap.put("dweb", sjlrMzda.getDweb());
  1275. List<SjlrMzxxxxDTO> mzxxxxList = sjlrMzdaDAO.getTtMzxxListByParam(paramMap);
  1276. List<SjlrMzxxDTO> mzxxList = new ArrayList<SjlrMzxxDTO>();
  1277. //List<SjlrPzjl> pzs = new ArrayList<SjlrPzjl>();
  1278. int i = 1;
  1279. for (SjlrMzxxxxDTO sjlrMzxxxxDTO : mzxxxxList) {
  1280. SjlrMzxxDTO mzxxDTO = new SjlrMzxxDTO();
  1281. SjlrPzjl sjlrPzjl = new SjlrPzjl();
  1282. sjlrPzjl.setPzsj(sjlrMzxxxxDTO.getPzsj());
  1283. sjlrPzjl.setPzsm(sjlrMzxxxxDTO.getPzsm());//配种说明
  1284. for (XtGydm xtGydm : pzsmList) {
  1285. if (xtGydm.getDmid().equals(String.valueOf(sjlrPzjl.getPzsm()))) {
  1286. sjlrPzjl.setPzsmStr(xtGydm.getDmmc());
  1287. }
  1288. }
  1289. if (StringUtils.hasText(sjlrMzxxxxDTO.getYpgzeb())) {
  1290. SjlrGzdaExample gzEx = new SjlrGzdaExample();
  1291. SjlrGzdaExample.Criteria gzCr = gzEx.createCriteria();
  1292. gzCr.andDwebEqualTo(sjlrMzxxxxDTO.getYpgzeb()).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1293. List<SjlrGzda> gzList = sjlrGzdaDAO.selectByExample(gzEx);
  1294. if (gzList.size() > 0) {
  1295. sjlrPzjl.setYpgzeb(gzList.get(0).getEph());//一配耳牌
  1296. }
  1297. } else {
  1298. sjlrPzjl.setYpgzeb("未记录");
  1299. }
  1300. sjlrPzjl.setYppf(sjlrMzxxxxDTO.getYppf());//一配评分
  1301. sjlrPzjl.setFqjg(Integer.parseInt(sjlrMzxxxxDTO.getFqjg()));//发情间隔
  1302. Calendar calendar = new GregorianCalendar();
  1303. calendar.setTime(sjlrMzxxxxDTO.getPzsj());
  1304. calendar.add(Calendar.DATE, + 114);
  1305. sjlrPzjl.setYcrq(calendar.getTime());//预产日期
  1306. mzxxDTO.setSjlrPzjl(sjlrPzjl);
  1307. //妊娠数据,妊娠与配种必定是有的 ,sql决定
  1308. SjlrRsjl sjlrRsjl = new SjlrRsjl();
  1309. sjlrRsjl.setRssj(sjlrMzxxxxDTO.getRssj());
  1310. //舍栏
  1311. if (StringUtils.hasText(sjlrMzxxxxDTO.getRsjg())) {
  1312. for (XtGydm xtGydm : rsJgList) {
  1313. if (sjlrMzxxxxDTO.getRsjg().equals(xtGydm.getDmid())) {
  1314. sjlrRsjl.setRsjgStr(xtGydm.getDmmc());
  1315. }
  1316. }
  1317. }
  1318. mzxxDTO.setSjlrRsjl(sjlrRsjl);
  1319. if (StringUtils.hasText(sjlrMzxxxxDTO.getRsid())) {//分娩
  1320. SjlrFmjl sjlrFmjl = new SjlrFmjl();
  1321. sjlrFmjl.setRsid(Integer.parseInt(sjlrMzxxxxDTO.getRsid()));
  1322. sjlrFmjl.setFmsj(sjlrMzxxxxDTO.getFmsj());
  1323. int jzgs = !StringUtils.hasText(sjlrMzxxxxDTO.getJzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getJzgs());
  1324. sjlrFmjl.setJzgs(jzgs);
  1325. int rzgs = !StringUtils.hasText(sjlrMzxxxxDTO.getRzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getRzgs());
  1326. sjlrFmjl.setRzgs(rzgs);
  1327. int jxgs = !StringUtils.hasText(sjlrMzxxxxDTO.getJxgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getJxgs());
  1328. sjlrFmjl.setJxgs(jxgs);
  1329. int mnygs = !StringUtils.hasText(sjlrMzxxxxDTO.getMnygs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getMnygs());
  1330. sjlrFmjl.setMnygs(mnygs);
  1331. int stgs = !StringUtils.hasText(sjlrMzxxxxDTO.getStgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getStgs());
  1332. sjlrFmjl.setStgs(stgs);
  1333. sjlrFmjl.setHzgs(String.valueOf(jzgs + rzgs + jxgs));
  1334. sjlrFmjl.setSzgs(String.valueOf(jzgs + rzgs + jxgs + mnygs + stgs));
  1335. sjlrFmjl.setGzgs(!StringUtils.hasText(sjlrMzxxxxDTO.getGzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getGzgs()));
  1336. sjlrFmjl.setMzgs(!StringUtils.hasText(sjlrMzxxxxDTO.getMzgs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getMzgs()));
  1337. ws++;
  1338. hz = hz + jzgs + rzgs + jxgs;//活仔
  1339. yctc++;//已产胎次
  1340. mzxxDTO.setSjlrFmjl(sjlrFmjl);
  1341. if (StringUtils.hasText(sjlrMzxxxxDTO.getFmid())) {//断奶
  1342. SjlrDnjl sjlrDnjl = new SjlrDnjl();
  1343. sjlrDnjl.setFmid(Integer.parseInt(sjlrMzxxxxDTO.getFmid()));
  1344. sjlrDnjl.setDnsj(sjlrMzxxxxDTO.getDnsj());
  1345. int dnsl = !StringUtils.hasText(sjlrMzxxxxDTO.getZzzs()) ? 0 : Integer.parseInt(sjlrMzxxxxDTO.getZzzs());
  1346. sjlrDnjl.setDnsl(String.valueOf(dnsl));
  1347. sjlrDnjl.setDnwz(!StringUtils.hasText(sjlrMzxxxxDTO.getDnwz()) ? "0" : sjlrMzxxxxDTO.getDnwz());
  1348. mzxxDTO.setSjlrDnjl(sjlrDnjl);
  1349. wjdnts = wjdnts + dnsl;
  1350. }
  1351. }
  1352. mzxxDTO.setHh(String.valueOf(i));
  1353. i++;
  1354. mzxxList.add(mzxxDTO);
  1355. }
  1356. Collections.reverse(mzxxList);
  1357. sjlrMzda.setYctc(String.valueOf(yctc));
  1358. sjlrMzda.setWjhz(ws == 0 ? "0" : String.valueOf(hz / ws));
  1359. sjlrMzda.setWjdn(yctc == 0 ? "0" : String.valueOf(wjdnts / yctc));
  1360. mv.addObject("sjlrMzda", sjlrMzda);
  1361. mv.addObject("mzxxList", mzxxList);
  1362. }
  1363. mv.addObject("ztsl",ztsl);
  1364. mv.addObject("edit",edit);
  1365. mv.addObject("from",from);
  1366. return mv;
  1367. }
  1368. /**
  1369. * 获取种猪温度
  1370. * @param request
  1371. * @param response
  1372. * @return
  1373. * @throws Exception
  1374. */
  1375. public ModelAndView geHaifmvtZzwdMain(HttpServletRequest request,
  1376. HttpServletResponse response) throws Exception {
  1377. ModelAndView mv = new ModelAndView("haifmp/sjlr/da/zzwdMain.htm");
  1378. mv.addObject("dweb", request.getParameter("dweb"));
  1379. return mv;
  1380. }
  1381. /**
  1382. * 加载温度统计图
  1383. *
  1384. * @param request
  1385. * @param response
  1386. * @return
  1387. * @throws Exception
  1388. */
  1389. public void getHaifmvZzwdTjt(HttpServletRequest request,
  1390. HttpServletResponse response) throws Exception {
  1391. //获取最近7天的体温
  1392. String data = "";
  1393. String dweb = request.getParameter("dweb");
  1394. if (StringUtils.hasText(dweb)) {
  1395. Map<String, Object> wdMap = new HashMap<String, Object>();
  1396. wdMap.put("dweb", dweb);
  1397. wdMap.put("ss", "1");
  1398. List<SjlrZzwd> zzwdList = sjlrZzwdDAO.getZzwdListByParam(wdMap);
  1399. if (zzwdList != null && zzwdList.size() > 0) {
  1400. String[] Colors = XtAppConstant.TJTCOLORS;
  1401. HighchartsDTO hd = new HighchartsDTO();
  1402. String[] value = new String[zzwdList.size()];
  1403. List<String[]> tjtList = new ArrayList<String[]>();
  1404. for (int i = 0; i < zzwdList.size(); i++) {
  1405. SjlrZzwd sjlrZzwd = zzwdList.get(i);
  1406. long time = sjlrZzwd.getScsj().getTime();
  1407. value[i] = "{x:" + time + ",y:" + sjlrZzwd.getDqwd() + "}";
  1408. }
  1409. tjtList.add(value);
  1410. hd.setColor(Arrays.copyOfRange(Colors, 0, 1));
  1411. hd.setDateFormat("%H:%M");
  1412. hd.setNames(new String[]{"体温"});
  1413. hd.setValues(tjtList);
  1414. hd.setYdw("℃");
  1415. hd.setTitle("");
  1416. data = JsonUtil.getJsonString4JavaObj(hd);
  1417. }
  1418. }
  1419. this.renderJsonData(response, data);
  1420. }
  1421. /**
  1422. * 批量更新其他表中的动物耳标
  1423. * @param 被替换的动物耳标,新的动物耳标,修改人
  1424. * @return
  1425. * @throws Exception
  1426. */
  1427. @SuppressWarnings("unused")
  1428. private void updateDweb(String oldDweb , String newDweb , String xgr) throws Exception {
  1429. int count = 0;
  1430. //检查采精表中有无此耳标号
  1431. SjlrCjjlExample cjEx = new SjlrCjjlExample();
  1432. SjlrCjjlExample.Criteria cjCr = cjEx.createCriteria();
  1433. cjCr.andDwebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1434. count = sjlrCjjlDAO.countByExample(cjEx);
  1435. if (count > 0 ) {
  1436. //如果采精表中有此动物耳标,则更新
  1437. SjlrCjjl sjlrCjjl = new SjlrCjjl();
  1438. sjlrCjjl.setXgr(xgr);
  1439. sjlrCjjl.setXgsj(commonService.getCurrentDate());
  1440. sjlrCjjl.setZfbz(XtAppConstant.ZFBZ_VALID);
  1441. sjlrCjjl.setDweb(newDweb);
  1442. sjlrCjjlDAO.updateByExampleSelective(sjlrCjjl, cjEx);
  1443. count = 0;
  1444. }
  1445. //检查配种表中有无此耳标号
  1446. SjlrPzjlExample pzgzEx = new SjlrPzjlExample();
  1447. SjlrPzjl sjlrPzjl = new SjlrPzjl();
  1448. sjlrPzjl.setXgr(xgr);
  1449. sjlrPzjl.setXgsj(commonService.getCurrentDate());
  1450. sjlrPzjl.setZfbz(XtAppConstant.ZFBZ_VALID);
  1451. SjlrPzjlExample.Criteria pzmzCr = pzgzEx.createCriteria();
  1452. pzmzCr.andMzebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1453. count = sjlrPzjlDAO.countByExample(pzgzEx);
  1454. if (count > 0) {
  1455. //如果配种表中有此母猪耳标,则更新母猪耳标
  1456. sjlrPzjl.setMzeb(newDweb);
  1457. sjlrPzjlDAO.updateByExampleSelective(sjlrPzjl, pzgzEx);
  1458. count = 0;
  1459. }
  1460. SjlrPzjlExample pzmzEx = new SjlrPzjlExample();
  1461. SjlrPzjlExample.Criteria pzgzCr = pzmzEx.createCriteria();
  1462. pzgzCr.andYpgzebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1463. count = sjlrPzjlDAO.countByExample(pzmzEx);
  1464. if (count > 0) {
  1465. //如果配种表中有此首配公猪耳标,则更新
  1466. sjlrPzjl.setYpgzeb(newDweb);
  1467. sjlrPzjlDAO.updateByExampleSelective(sjlrPzjl, pzmzEx);
  1468. count = 0;
  1469. }
  1470. //检查妊娠表中有无此耳标号
  1471. SjlrRsjlExample rsEx = new SjlrRsjlExample();
  1472. SjlrRsjlExample.Criteria rsCr = rsEx.createCriteria();
  1473. rsCr.andDwebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1474. count = sjlrRsjlDAO.countByExample(rsEx);
  1475. if (count > 0) {
  1476. SjlrRsjl sjlrRsjl = new SjlrRsjl();
  1477. sjlrRsjl.setXgr(xgr);
  1478. sjlrRsjl.setXgsj(commonService.getCurrentDate());
  1479. sjlrRsjl.setZfbz(XtAppConstant.ZFBZ_VALID);
  1480. sjlrRsjl.setDweb(newDweb);
  1481. sjlrRsjlDAO.updateByExampleSelective(sjlrRsjl, rsEx);
  1482. count = 0;
  1483. }
  1484. //检查分娩表中有无次耳标号
  1485. SjlrFmjlExample fmEx = new SjlrFmjlExample();
  1486. SjlrFmjlExample.Criteria fmCr = fmEx.createCriteria();
  1487. fmCr.andDwebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1488. count = sjlrFmjlDAO.countByExample(fmEx);
  1489. if (count > 0) {
  1490. SjlrFmjl sjlrFmjl = new SjlrFmjl();
  1491. sjlrFmjl.setXgr(xgr);
  1492. sjlrFmjl.setXgsj(commonService.getCurrentDate());
  1493. sjlrFmjl.setZfbz(XtAppConstant.ZFBZ_VALID);
  1494. sjlrFmjl.setDweb(newDweb);
  1495. sjlrFmjlDAO.updateByExampleSelective(sjlrFmjl, fmEx);
  1496. count = 0;
  1497. }
  1498. //检查断奶表中有无此耳标号
  1499. SjlrDnjlExample dnEx = new SjlrDnjlExample();
  1500. SjlrDnjlExample.Criteria dnCr = dnEx.createCriteria();
  1501. dnCr.andDwebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1502. count = sjlrDnjlDAO.countByExample(dnEx);
  1503. if (count > 0) {
  1504. SjlrDnjl sjlrDnjl = new SjlrDnjl();
  1505. sjlrDnjl.setXgr(xgr);
  1506. sjlrDnjl.setXgsj(commonService.getCurrentDate());
  1507. sjlrDnjl.setZfbz(XtAppConstant.ZFBZ_VALID);
  1508. sjlrDnjl.setDweb(newDweb);
  1509. sjlrDnjlDAO.updateByExampleSelective(sjlrDnjl, dnEx);
  1510. count = 0;
  1511. }
  1512. //检查淘汰表里有无此耳标号
  1513. SjlrZzttExample ttEx = new SjlrZzttExample();
  1514. SjlrZzttExample.Criteria ttCr = ttEx.createCriteria();
  1515. ttCr.andDwebEqualTo(oldDweb).andZfbzEqualTo(XtAppConstant.ZFBZ_VALID);
  1516. count = sjlrZzttDAO.countByExample(ttEx);
  1517. if (count > 0) {
  1518. SjlrZztt sjlrZztt = new SjlrZztt();
  1519. sjlrZztt.setXgr(xgr);
  1520. sjlrZztt.setXgsj(commonService.getCurrentDate());
  1521. sjlrZztt.setZfbz(XtAppConstant.ZFBZ_VALID);
  1522. sjlrZztt.setDweb(newDweb);
  1523. sjlrZzttDAO.updateByExampleSelective(sjlrZztt, ttEx);
  1524. count = 0;
  1525. }
  1526. }
  1527. /**
  1528. * 获取公用代码
  1529. * @param lbmc
  1530. * @return
  1531. * @throws Exception
  1532. */
  1533. private List<XtGydm> getGydm(String lbmc) {
  1534. return xtGydmDAO.selectGydmByLbmc(lbmc);
  1535. }
  1536. public void setCommonService(CommonService commonService) {
  1537. this.commonService = commonService;
  1538. }
  1539. public void setXtGydmDAO(XtGydmDAO xtGydmDAO) {
  1540. this.xtGydmDAO = xtGydmDAO;
  1541. }
  1542. public void setSjlrGzdaDAO(SjlrGzdaDAO sjlrGzdaDAO) {
  1543. this.sjlrGzdaDAO = sjlrGzdaDAO;
  1544. }
  1545. public void setDaMcdaDAO(DaMcdaDAO daMcdaDAO) {
  1546. this.daMcdaDAO = daMcdaDAO;
  1547. }
  1548. public void setSjlrMzdaDAO(SjlrMzdaDAO sjlrMzdaDAO) {
  1549. this.sjlrMzdaDAO = sjlrMzdaDAO;
  1550. }
  1551. public void setSjlrZzwdDAO(SjlrZzwdDAO sjlrZzwdDAO) {
  1552. this.sjlrZzwdDAO = sjlrZzwdDAO;
  1553. }
  1554. public void setSjlrCjjlDAO(SjlrCjjlDAO sjlrCjjlDAO) {
  1555. this.sjlrCjjlDAO = sjlrCjjlDAO;
  1556. }
  1557. public void setSjlrPzjlDAO(SjlrPzjlDAO sjlrPzjlDAO) {
  1558. this.sjlrPzjlDAO = sjlrPzjlDAO;
  1559. }
  1560. public void setSjlrRsjlDAO(SjlrRsjlDAO sjlrRsjlDAO) {
  1561. this.sjlrRsjlDAO = sjlrRsjlDAO;
  1562. }
  1563. public void setSjlrFmjlDAO(SjlrFmjlDAO sjlrFmjlDAO) {
  1564. this.sjlrFmjlDAO = sjlrFmjlDAO;
  1565. }
  1566. public void setSjlrDnjlDAO(SjlrDnjlDAO sjlrDnjlDAO) {
  1567. this.sjlrDnjlDAO = sjlrDnjlDAO;
  1568. }
  1569. public void setSjlrZzttDAO(SjlrZzttDAO sjlrZzttDAO) {
  1570. this.sjlrZzttDAO = sjlrZzttDAO;
  1571. }
  1572. }