/// <summary> /// 保存(传入事务处理) /// </summary> /// <param name="p_Entity"></param> /// <param name="p_BE"></param> /// <param name="sqlTrans"></param> public void RSave2(InvoiceOperation p_Entity, BaseEntity[] p_BE, BaseEntity[] p_BE2, IDBTransAccess sqlTrans) { try { string sql = "DELETE FROM Finance_InvoiceOperationDts WHERE MainID=" + p_Entity.ID.ToString(); sql += " AND ID NOT IN" + string.Format("({0})", GetIDExist(p_BE)); sqlTrans.ExecuteNonQuery(sql); //删除原单据里应该删除的明细数据,即数据库里有但是UI里已经删除的数据 sql = "SELECT ISNULL(MAX(Seq),0)+1 As MSEQ FROM Finance_InvoiceOperationDts WHERE MainID=" + p_Entity.ID.ToString(); ////找到最大的Seq 将获得最大Seq的语句放到循环外更高效(多人操作时会有问题吗?) int MSEQ = SysConvert.ToInt32(sqlTrans.Fill(sql).Rows[0][0].ToString()); for (int i = 0; i < p_BE.Length; i++) { InvoiceOperationDts entitydts = (InvoiceOperationDts)p_BE[i]; if (entitydts.ID != 0)//ID不为0说明数据库中已经存在 { this.RUpdate(entitydts, sqlTrans); } else { entitydts.Seq = MSEQ; entitydts.MainID = p_Entity.ID; this.RAdd(entitydts, sqlTrans); MSEQ++;//最大值加1 } } sql = "SELECT ISNULL(MAX(Seq),0)+1 As MSEQ FROM Finance_InvoiceYOperationDts WHERE MainID=" + p_Entity.ID.ToString();////找到最大的Seq 将获得最大Seq的语句放到循环外更高效(多人操作时会有问题吗?) MSEQ = SysConvert.ToInt32(sqlTrans.Fill(sql).Rows[0][0].ToString()); InvoiceYOperationDtsRule rule2 = new InvoiceYOperationDtsRule(); for (int i = 0; i < p_BE2.Length; i++) { InvoiceYOperationDts entitydts2 = (InvoiceYOperationDts)p_BE2[i]; if (entitydts2.ID != 0)//ID不为0说明数据库中已经存在 { rule2.RUpdate(entitydts2, sqlTrans); } else { entitydts2.Seq = MSEQ; entitydts2.MainID = p_Entity.ID; rule2.RAdd(entitydts2, sqlTrans); MSEQ++;//最大值加1 } } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 修改 /// </summary> /// <param name="p_BE">要修改的实体</param> /// <param name="sqlTrans">事务类</param> public void RUpdate2(BaseEntity p_BE, BaseEntity[] p_BE2, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); InvoiceOperation entity = (InvoiceOperation)p_BE; string sql = "SELECT FormNo FROM Finance_InvoiceOperation WHERE FormNo=" + SysString.ToDBString(entity.FormNo); sql += " AND ID<>" + entity.ID; DataTable dt = sqlTrans.Fill(sql); if (dt.Rows.Count > 0) { throw new BaseException("单号已存在,异常操作,请联系管理员检查"); } if (entity.InvoiceNO != "") { sql = "SELECT ID FROM Finance_InvoiceOperation WHERE InvoiceNO=" + SysString.ToDBString(entity.InvoiceNO); sql += " AND ID<>" + entity.ID; dt = sqlTrans.Fill(sql); if (dt.Rows.Count > 0) { throw new BaseException("发票号已存在,请重新输入"); } } InvoiceOperationCtl control = new InvoiceOperationCtl(sqlTrans); control.Update(entity); sql = "DELETE Finance_InvoiceYOperationDts WHERE MainID=" + SysString.ToDBString(entity.ID); sqlTrans.ExecuteNonQuery(sql); for (int i = 0; i < p_BE2.Length; i++) { InvoiceYOperationDtsRule rule = new InvoiceYOperationDtsRule(); InvoiceYOperationDts entityDts = (InvoiceYOperationDts)p_BE2[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 RAdd2(BaseEntity p_BE, BaseEntity[] p_BE2, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); InvoiceOperation entity = (InvoiceOperation)p_BE; string sql = "SELECT FormNo FROM Finance_InvoiceOperation WHERE FormNo=" + SysString.ToDBString(entity.FormNo); DataTable dt = sqlTrans.Fill(sql); if (dt.Rows.Count > 0) { throw new BaseException("单号已存在,请重新生成"); } if (entity.InvoiceNO != "") { sql = "SELECT ID FROM Finance_InvoiceOperation WHERE InvoiceNO=" + SysString.ToDBString(entity.InvoiceNO); dt = sqlTrans.Fill(sql); if (dt.Rows.Count > 0) { throw new BaseException("发票号已存在,请重新输入"); } } InvoiceOperationCtl control = new InvoiceOperationCtl(sqlTrans); entity.ID = (int)EntityIDTable.GetID((long)SysEntity.Finance_InvoiceOperation, sqlTrans); control.AddNew(entity); for (int i = 0; i < p_BE2.Length; i++) { InvoiceYOperationDtsRule rule = new InvoiceYOperationDtsRule(); InvoiceYOperationDts entityDts = (InvoiceYOperationDts)p_BE2[i]; entityDts.MainID = entity.ID; entityDts.Seq = i + 1; rule.RAdd(entityDts, sqlTrans); } FormNoControlRule rulest = new FormNoControlRule(); rulest.RAddSort((int)FormNoControlEnum.发票单号, sqlTrans); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }