/// <summary> /// 新增(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RAdd(BaseEntity p_BE, BaseEntity p_BEAdd, BaseEntity[] p_BE2, BaseEntity[] p_BE3, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); FabricProcess entity = (FabricProcess)p_BE; FabricProcessCtl control = new FabricProcessCtl(sqlTrans); string sql = "SELECT FormNo FROM WO_FabricProcess WHERE FormNo=" + SysString.ToDBString(entity.FormNo); DataTable dt = sqlTrans.Fill(sql); if (dt.Rows.Count > 0) { throw new BaseException("单号已存在,请重新生成"); } entity.ID = (int)EntityIDTable.GetID((long)SysEntity.WO_FabricProcess, sqlTrans); control.AddNew(entity); FormNoControlRule fnrule = new FormNoControlRule(); fnrule.RAddSort("WO_FabricProcess", "FormNo", entity.ProcessTypeID, sqlTrans); FabricProcessAddRule ruleAdd = new FabricProcessAddRule(); FabricProcessAdd entityAdd = (FabricProcessAdd)p_BEAdd; entityAdd.ID = entity.ID; ruleAdd.RAdd(entityAdd, sqlTrans); for (int i = 0; i < p_BE2.Length; i++) { FabricProcessDtsRule rule = new FabricProcessDtsRule(); FabricProcessDts entityDts = (FabricProcessDts)p_BE2[i]; entityDts.MainID = entity.ID; entityDts.Seq = i + 1; rule.RAdd(entityDts, sqlTrans); } for (int i = 0; i < p_BE3.Length; i++) { FabricProcessPBDtsRule rule = new FabricProcessPBDtsRule(); FabricProcessPBDts entityDts = (FabricProcessPBDts)p_BE3[i]; entityDts.MainID = entity.ID; entityDts.Seq = i + 1; rule.RAdd(entityDts, sqlTrans); } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 修改 /// </summary> /// <param name="p_BE">要修改的实体</param> /// <param name="sqlTrans">事务类</param> public void RUpdate(BaseEntity p_BE, BaseEntity p_BEAdd, BaseEntity[] p_BE2, BaseEntity[] p_BE3, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); FabricProcess entity = (FabricProcess)p_BE; FabricProcessCtl control = new FabricProcessCtl(sqlTrans); control.Update(entity); FabricProcessDtsRule rule = new FabricProcessDtsRule(); rule.RSave(entity, p_BE2, sqlTrans); string sql = "DELETE WO_FabricProcessAdd WHERE ID=" + SysString.ToDBString(entity.ID); sqlTrans.ExecuteNonQuery(sql); sql = "DELETE WO_FabricProcessPBDts WHERE MainID=" + SysString.ToDBString(entity.ID); sqlTrans.ExecuteNonQuery(sql); FabricProcessAddRule ruleAdd = new FabricProcessAddRule(); FabricProcessAdd entityAdd = (FabricProcessAdd)p_BEAdd; entityAdd.ID = entity.ID; ruleAdd.RAdd(entityAdd, sqlTrans); for (int i = 0; i < p_BE3.Length; i++) { FabricProcessPBDtsRule rule2 = new FabricProcessPBDtsRule(); FabricProcessPBDts entityDts = (FabricProcessPBDts)p_BE3[i]; entityDts.MainID = entity.ID; entityDts.Seq = i + 1; rule2.RAdd(entityDts, sqlTrans); } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }