/** @param 从业人员信息(t_qyryxx) 修改与t_qyryxx表有直接或间接外键关联的所有表的qyid,但不包括人员历史表 */ public boolean updateQyryxxForeignKey(Qyryxx qyryxx, Qyryxx qyryxx_bak) { int ryid_bak = qyryxx_bak.getRyid(); int qyid_bak = qyryxx_bak.getQyid(); boolean isSuccess = false; Qyryxx qyryxxlz = new Qyryxx(); qyryxxlz.setRyid(qyryxx_bak.getRyid()); Date currentDate = new Date(); qyryxxlz.setScbz(2); qyryxxDao.updateQyryxx(qyryxxlz); // 插入旧的从业人员信息,企业id改变了 Qyryxx qyryxxOld = new Qyryxx(); qyryxxOld = qyryxx_bak; qyryxxOld.setQyid(qyryxx.getQyid()); qyryxxOld = qyryxxDao.insertQyryxx(qyryxxOld); qyryxx.setRyid(qyryxxOld.getRyid()); // 更新新插入的信息 qyryxxDao.updateQyryxx(qyryxx); // 更新icksl表 Qyjbxx qyjbxxa = new Qyjbxx(); qyjbxxa.setQyid(qyryxx.getQyid()); qyjbxxa = qyjbxxDao.getQyjbxx(qyjbxxa); /*Icksl icksla = new Icksl(); icksla.setRyid(ryid_bak); icksla.setZxbz("0"); icksla =ickslDao.getIckslyj(icksla);//拿出这个ryid的最后的icksl记录 Icksl ickslgx = new Icksl(); ickslgx.setIckslid(icksla.getIckslid()); ickslgx.setQybm(qyjbxxa.getQybm()); ickslgx.setQyid(qyjbxxa.getQyid()); ickslgx.setRyid(qyryxx.getRyid()); ickslgx.setHylbdm(qyryxx.getHylbdm()); ickslgx.setHylb(qyryxx.getHylb()); ickslDao.updateIckslByqybg(ickslgx);*/ // 更新qyrysh Qyrysh qyrysh = new Qyrysh(); qyrysh.setRyid(ryid_bak); qyrysh.setQyid(qyjbxxa.getQyid()); qyrysh.setNewRyid(qyryxx.getRyid()); isSuccess = qyryshDao.updateQyryshByqybg(qyrysh) > 0; // 新插入从表数据 int ryid = qyryxx.getRyid(); int qyid = qyryxx.getQyid(); // 照片 Qyry_zp qyry_zp = new Qyry_zp(); qyry_zp.setRyid(ryid_bak); qyry_zp.setQyid(qyid_bak); qyry_zp.setTplx("0"); qyry_zp = qyry_zpDao.getQyry_zp(qyry_zp); if (qyry_zp != null) { qyry_zp.setRyid(ryid); qyry_zp.setQyid(qyid); qyry_zpDao.updateQyrybg_zp(qyry_zp); qyryxx.setZpid(qyry_zp.getZpid()); } // 外国 Wgcyryxx wgcyryxx = new Wgcyryxx(); wgcyryxx.setRyid(ryid_bak); wgcyryxx.setQyid(qyid_bak); wgcyryxx = wgcyryxxDao.getWgcyryxx(wgcyryxx); if (wgcyryxx != null) { wgcyryxx.setRyid(ryid); wgcyryxx.setQyid(qyid); wgcyryxxDao.insertWgcyryxx(wgcyryxx); } // 奖惩 Ryjcxx ryjcxx = new Ryjcxx(); ryjcxx.setRyid(ryid_bak); ryjcxx.setQyid(qyid_bak); List list = ryjcxxDao.getListRyjcxx(ryjcxx); if (list != null) { for (int i = 0; i < list.size(); i++) { ryjcxx = (Ryjcxx) list.get(i); ryjcxx.setRyid(ryid); ryjcxx.setQyid(qyid); ryjcxxDao.insertRyjcxx(ryjcxx); } } // 核查 Qyryxxhc qyryxxhc = new Qyryxxhc(); qyryxxhc.setRyid(ryid_bak); qyryxxhc.setQyid(qyid_bak); qyryxxhc = qyryxxhcDao.getQyryxxhc(qyryxxhc); if (qyryxxhc != null) { qyryxxhc.setRyid(ryid); qyryxxhc.setQyid(qyid); qyryxxhcDao.insertQyryxxhc(qyryxxhc); } // 体检 Qyry_tjxx qyry_tjxx = new Qyry_tjxx(); qyry_tjxx.setRyid(ryid_bak); qyry_tjxx.setQyid(qyid_bak); List listTjxx = qyry_tjxxDao.getListQyry_tjxx(qyry_tjxx); if (listTjxx != null) { for (int j = 0; j < listTjxx.size(); j++) { qyry_tjxx = (Qyry_tjxx) listTjxx.get(j); qyry_tjxx.setRyid(ryid); qyry_tjxx.setQyid(qyid); qyry_tjxxDao.insertQyry_tjxx(qyry_tjxx); } } qyryxx_bak.setRyid(ryid_bak); qyryxx_bak.setQyid(qyid_bak); return isSuccess; }
/** @param 企业人员信息(t_qyryxx) 增加 */ public Qyryxx insertQyryxx(Qyryxx qyryxx) throws Exception { // TODO: implement Date currentDate = new Date(); Qyryxx qyryxxNew = new Qyryxx(); Qyry_zp qyry_zp = new Qyry_zp(); Wgcyryxx wgcyryxx = new Wgcyryxx(); List qyry_zpList = new ArrayList(); Qyryxx qyryxxExistList = new Qyryxx(); Qyjbxx qyjbxx = new Qyjbxx(); qyjbxx.setQyid(qyryxx.getQyid()); qyjbxx = qyjbxxDao.getQyjbxx(qyjbxx); // 得到从业人员编号 // 娱乐业、公共场所行业规则:企业编码前9位+8位年份+4位流水号 // 其他行业规则 :企业编码+2位年份+4位流水号 (modified by mds at 20100120) String hylbdm = qyjbxx.getHylbdm(); Map scbmMap = new HashMap(); scbmMap.put("p_bmfl", "RY"); if (hylbdm.equals("J") || hylbdm.equals("K")) scbmMap.put("p_xzqh", qyjbxx.getQybm().substring(0, 9)); else scbmMap.put("p_xzqh", qyjbxx.getQybm()); String sssf = QjblUtil.queryQjblVal("sssf"); // 所属省份 scbmMap.put("p_sssf", sssf); if (hylbdm.equals("J") || hylbdm.equals("K")) scbmMap.put("p_scgz", 2); else scbmMap.put("p_scgz", 4); // 若前台传入的cyrybh为空,则调用编码生成程序生成编码。 if (qyryxx.getCyrybh() == null || "".equals(qyryxx.getCyrybh())) qyryxx.setCyrybh(scbmDao.getScbm(scbmMap)); qyryxxExistList = qyryxxDao.getIsQyrybhExist(qyryxx); while (qyryxxExistList != null) { // 校验从业人员编号是否存在,存在从新生成 qyryxx.setCyrybh(scbmDao.getScbm(scbmMap)); qyryxxExistList = qyryxxDao.getIsQyrybhExist(qyryxx); } // 增加从业人员信息表 qyryxx.setScbz(0); qyryxx.setZxbz("0"); qyryxx.setBiduiflag("0"); // 未比对 // 增加从业人员信息表 if ("0".equals(qyryxx.getCyrylbdm())) { qyryxx.setCyzjdm("111"); qyryxx.setCyzj("公民身份号码"); qyryxx.setGjdm("CHN"); qyryxx.setGj("中国"); if (qyryxx.getZjzt() != null) { if ("0".equals(qyryxx.getZjzt())) // 公民身份号码符合校验规则 { qyryxx.setZt("0"); } else qyryxx.setZt("5"); } else qyryxx.setZt("0"); } else { // 若为境外从业人员,则姓名字段为英文名+" "+英文姓 if (qyryxx.getXm() == null || "".equals(qyryxx.getXm())) { qyryxx.setXm(qyryxx.getWgcyryxx().getYwm() + " " + qyryxx.getWgcyryxx().getYwx()); } qyryxx.setZt("0"); } qyryxx.setXmpy(PinYinUtil.getHanyuPingYin(qyryxx.getXm())); qyryxx.setLrsj(currentDate); if (null != qyryxx.getLzrq() && !"".equals(qyryxx.getLzrq())) { qyryxx.setCyryzt("离职"); } qyryxxNew = qyryxxDao.insertQyryxx(qyryxx); if (qyryxx.getQyry_zp() != null) { qyry_zp = qyryxx.getQyry_zp(); qyry_zp.setRyid(qyryxxNew.getRyid()); qyry_zp.setQyid(qyryxxNew.getQyid()); qyry_zp.setTplx("0"); qyry_zp = qyry_zpDao.insertQyry_zp(qyry_zp); } // 增加外国从业人员信息表 if (qyryxx.getWgcyryxx() != null) { wgcyryxx = qyryxx.getWgcyryxx(); wgcyryxx.setRyid(qyryxxNew.getRyid()); wgcyryxx = wgcyryxxDao.insertWgcyryxx(wgcyryxx); } // 若从业人员状态为5-证件号码错,则插入从业人员核查表 if (qyryxx.getWgcyryxx() == null) { if ("5".equals(qyryxxNew.getZt())) { Garkktbsj garkktbsj = new com.aisino2.publicsystem.domain.Garkktbsj(); garkktbsj = garkktbsjService.insertGarkktbsj(garkktbsj); Qyryxxhc qyryxxhc = new Qyryxxhc(); qyryxxhc.setRyid(qyryxxNew.getRyid()); qyryxxhc.setGarkktbsjid(garkktbsj.getGarkktbsjid()); qyryxxhc.setHcwt("证件号码错"); qyryxxhcService.insertQyryxxhcByRyid(qyryxxhc); } } // 更新场所总人数 Map map = new HashMap(); map.put("p_oldQyid", 0); map.put("p_newQyid", qyryxxNew.getQyid()); qyZrsProcDao.updateQyzrs(map); // 人员信息操作日志 Ryxxczrz ryxxczrz = new Ryxxczrz(); ryxxczrz.setCzsj(currentDate); ryxxczrz.setCzlx("增加"); ryxxczrz.setQybm(qyjbxx.getQybm()); ryxxczrz.setCzr(qyryxx.getLrr()); ryxxczrz.setCyrybh(qyryxxNew.getCyrybh()); ryxxczrzDao.insertRyxxczrz(ryxxczrz); qyryxxNew.setQyry_zp(qyry_zp); qyryxxNew.setWgcyryxx(wgcyryxx); // 生成从业人员账号 int errCode = 0; if (sczhFlag(qyryxxNew.getHylbdm(), qyryxxNew.getGwbh()).equals("1")) { if ("1".equals(queryQjbl(qyryxxNew.getHylbdm() + "tbsczh"))) { // 同步生成账号 GgQyyh qyyh = new GgQyyh(); qyyh.setRyid(qyryxxNew.getRyid()); errCode = ggQyyhDao.insertQyYgyh(qyyh); if (errCode == 1) return null; } } if (null != qyryxx.getLzrq() && !"".equals(qyryxx.getLzrq())) { //// 注销员工用户 int errResult = 0; if (sczhFlag(qyryxxNew.getHylbdm(), qyryxxNew.getGwbh()).equals("1")) { if (getUser(qyryxxNew.getCyrybh()).equals("1")) { GgQyyh qyyh = new GgQyyh(); qyyh.setRyid(qyryxx.getRyid()); qyyh.setIsval("0"); // 是否可见 errResult = ggQyyhDao.zhuxQyYgyh(qyyh); } } } return qyryxxNew; }