private SaleOrderCapDts[] GetEntityDts() { int Num = 0; for (int i = 0; i < gridView1.RowCount; i++) { if (SysConvert.ToString(gridView1.GetRowCellValue(i, "PayStepTypeID")) != string.Empty) { Num++; } } SaleOrderCapDts[] entityDts = new SaleOrderCapDts[Num]; Num = 0; for (int j = 0; j < gridView1.RowCount; j++) { if (SysConvert.ToString(gridView1.GetRowCellValue(j, "PayStepTypeID")) != string.Empty) { entityDts[Num] = new SaleOrderCapDts(); entityDts[Num].CapName = SysConvert.ToString(gridView1.GetRowCellValue(j, "CapName")); entityDts[Num].PayStepTypeID = SysConvert.ToInt32(gridView1.GetRowCellValue(j, "PayStepTypeID")); entityDts[Num].PayPer = SysConvert.ToDecimal(gridView1.GetRowCellValue(j, "PayPer")); entityDts[Num].PayLimitDate = SysConvert.ToDateTime(gridView1.GetRowCellValue(j, "PayLimitDate")); entityDts[Num].PayAmount = entityDts[Num].PayPer * m_Amount; entityDts[Num].Remark = SysConvert.ToString(gridView1.GetRowCellValue(j, "Remark")); Num++; } } return(entityDts); }
/// <summary> /// 保存(传入事务处理) /// </summary> /// <param name="p_Entity"></param> /// <param name="p_BE"></param> /// <param name="sqlTrans"></param> public void RSave(SaleOrder p_Entity, BaseEntity[] p_BE, IDBTransAccess sqlTrans) { try { string sql = "DELETE FROM Sale_SaleOrderCapDts WHERE MainID=" + p_Entity.ID.ToString(); sql += " AND ID NOT IN" + string.Format("({0})", GetIDExist(p_BE)); sqlTrans.ExecuteNonQuery(sql);//删除原单据里应该删除的明细数据,即数据库里有但是UI里已经删除的数据 for (int i = 0; i < p_BE.Length; i++) { SaleOrderCapDts entitydts = (SaleOrderCapDts)p_BE[i]; if (entitydts.ID != 0)//ID不为0说明数据库中已经存在 { this.RUpdate(entitydts, sqlTrans); } else { entitydts.MainID = p_Entity.ID; this.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 RAdd(int p_ID, BaseEntity[] p_BE, IDBTransAccess sqlTrans) { try { if (p_ID > 0) { string sql = "DELETE Sale_SaleOrderCapDts WHERE MainID=" + SysString.ToDBString(p_ID); sqlTrans.ExecuteNonQuery(sql); for (int i = 0; i < p_BE.Length; i++) { SaleOrderCapDtsRule rule = new SaleOrderCapDtsRule(); SaleOrderCapDts entity = (SaleOrderCapDts)p_BE[i]; entity.MainID = p_ID; entity.Seq = i + 1; rule.RAdd(entity, sqlTrans); } sql = "UPDATE Sale_SaleOrder SET FKFlag=1"; sql += " WHERE ID=" + SysString.ToDBString(p_ID); sqlTrans.ExecuteNonQuery(sql); } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 删除 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int Delete(BaseEntity p_Entity) { try { SaleOrderCapDts MasterEntity = (SaleOrderCapDts)p_Entity; if (MasterEntity.ID == 0) { return(0); } //删除主表数据 string Sql = ""; Sql = "DELETE FROM Sale_SaleOrderCapDts WHERE " + "ID=" + SysString.ToDBString(MasterEntity.ID); //执行 int AffectedRows = 0; if (!this.sqlTransFlag) { AffectedRows = this.ExecuteNonQuery(Sql); } else { AffectedRows = sqlTrans.ExecuteNonQuery(Sql); } return(AffectedRows); } catch (BaseException E) { throw new BaseException(E.Message, E); } catch (Exception E) { throw new BaseException(FrameWorkMessage.GetAlertMessage((int)Message.CommonDBDelete), E); } }
/// <summary> /// 检验字段值是否已存在 /// </summary> /// <param name="p_TableName">表名</param> /// <param name="p_FieldName">字段名</param> /// <param name="p_FieldValue">字段值</param> /// <param name="p_KeyField">主键(只考虑主键为ID的情况)</param> /// <param name="p_KeyValue">主键值</param> /// <param name="p_sqlTrans"></param> /// <returns></returns> private bool CheckFieldValueIsExist(BaseEntity p_BE, string p_FieldName, string p_FieldValue, IDBTransAccess p_sqlTrans) { SaleOrderCapDts entity = (SaleOrderCapDts)p_BE; bool ret = false; string sql = string.Format(" SELECT {0} FROM {1} WHERE 1=1 AND {0}={2} AND {3}<>{4}", p_FieldName, SaleOrderCapDts.TableName, SysString.ToDBString(p_FieldValue), "ID", entity.ID); DataTable dt = p_sqlTrans.Fill(sql); if (dt.Rows.Count != 0) { ret = true; } return(ret); }
/// <summary> /// 获得数据库里没有被删除的ID(即数据库里有而且UI里也没有删除的数据) /// </summary> /// <param name="p_BE"></param> /// <returns></returns> private string GetIDExist(BaseEntity[] p_BE) { string outstr = "0"; for (int i = 0; i < p_BE.Length; i++) { SaleOrderCapDts entitydts = (SaleOrderCapDts)p_BE[i]; if (entitydts.ID != 0) { outstr += "," + entitydts.ID; } } return(outstr); }
/// <summary> /// 删除 /// </summary> /// <param name="p_BE">要删除的实体</param> /// <param name="sqlTrans">事务类</param> public void RDelete(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); SaleOrderCapDts entity = (SaleOrderCapDts)p_BE; SaleOrderCapDtsCtl control = new SaleOrderCapDtsCtl(sqlTrans); control.Delete(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 新增(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RAdd(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); SaleOrderCapDts entity = (SaleOrderCapDts)p_BE; SaleOrderCapDtsCtl control = new SaleOrderCapDtsCtl(sqlTrans); entity.ID = (int)EntityIDTable.GetID((long)SysEntity.Sale_SaleOrderCapDts, sqlTrans); control.AddNew(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 检查将要操作的数据是否符合业务规则 /// </summary> /// <param name="p_BE"></param> private void CheckCorrect(BaseEntity p_BE) { SaleOrderCapDts entity = (SaleOrderCapDts)p_BE; }
/// <summary> /// 保存资金明细(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RSaveSaleCap(SaleOrder p_BEMain, IDBTransAccess sqlTrans) { try { string sql = string.Empty; sql = "SELECT * FROM Sale_SaleOrderCapDts WHERE MainID=" + p_BEMain.ID + " ORDER BY Seq"; DataTable dtOld = sqlTrans.Fill(sql);//找到原始的ID sql = "SELECT * FROM Data_PayMethodDts WHERE MainID=" + SysConvert.ToInt32(p_BEMain.PayMethodFlag) + " ORDER BY Seq"; DataTable dtPayMethodDts = sqlTrans.Fill(sql);//付款方式明细 sql = "SELECT ItemCode,SUM(Amount) Amount,MIN(DtsReqDate) DtsReqDate FROM Sale_SaleOrderDts WHERE MainID=" + p_BEMain.ID + " GROUP BY ItemCode"; DataTable dtSaleDts = sqlTrans.Fill(sql);//合同品种明细 //根据不同品种生成独立的付款明细 SaleOrderCapDts[] entityDts = new SaleOrderCapDts[dtPayMethodDts.Rows.Count * dtSaleDts.Rows.Count];//初始化资金明细实体数组 int ci = 0; for (int i = 0; i < dtPayMethodDts.Rows.Count; i++) { for (int m = 0; m < dtSaleDts.Rows.Count; m++)//多个品种生成独立的资金计划 { entityDts[ci] = new SaleOrderCapDts(); if (dtOld.Rows.Count > ci) { entityDts[ci].ID = SysConvert.ToInt32(dtOld.Rows[ci]["ID"]); } entityDts[ci].MainID = p_BEMain.ID; entityDts[ci].Seq = ci + 1; entityDts[ci].CapName = dtPayMethodDts.Rows[i]["Name"].ToString();//名称 entityDts[ci].PayStepTypeID = SysConvert.ToInt32(dtPayMethodDts.Rows[i]["PayStepTypeID"]); entityDts[ci].PayPer = SysConvert.ToDecimal(dtPayMethodDts.Rows[i]["PayPer"]); switch (SysConvert.ToInt32(dtPayMethodDts.Rows[i]["PayDateTypeInt"]))//根据付款判断日期类型类型 { case (int)EnumPayDateType.依据合同签署日: entityDts[ci].PayLimitDate = p_BEMain.OrderDate.AddDays(SysConvert.ToInt32(dtPayMethodDts.Rows[i]["DelayDayNum"])).Date; //合同日延后多少天 break; case (int)EnumPayDateType.依据发货日: //备注下发货日;读取默认交期;后续发货后回填实际日期 entityDts[ci].Remark = "根据发货日"; entityDts[ci].PayLimitDate = SysConvert.ToDateTime(dtSaleDts.Rows[m]["DtsReqDate"]).AddDays(SysConvert.ToInt32(dtPayMethodDts.Rows[i]["DelayDayNum"])).Date; break; } entityDts[ci].ItemCode = dtSaleDts.Rows[m]["ItemCode"].ToString(); entityDts[ci].PayAmount = SysConvert.ToDecimal(dtSaleDts.Rows[m]["Amount"]) * entityDts[ci].PayPer;//付款金额 ci++; } } this.RSave(p_BEMain, entityDts, sqlTrans);//保存明细 } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 新增 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int AddNew(BaseEntity p_Entity) { try { SaleOrderCapDts MasterEntity = (SaleOrderCapDts)p_Entity; if (MasterEntity.ID == 0) { return(0); } //新增主表数据 StringBuilder MasterField = new StringBuilder(); StringBuilder MasterValue = new StringBuilder(); MasterField.Append("INSERT INTO Sale_SaleOrderCapDts("); MasterValue.Append(" VALUES("); MasterField.Append("ID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.ID) + ","); MasterField.Append("MainID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.MainID) + ","); MasterField.Append("Seq" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.Seq) + ","); MasterField.Append("CapName" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.CapName) + ","); MasterField.Append("ItemCode" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.ItemCode) + ","); MasterField.Append("PayStepTypeID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.PayStepTypeID) + ","); MasterField.Append("PayPer" + ","); if (MasterEntity.PayPer != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.PayPer) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("PayAmount" + ","); if (MasterEntity.PayAmount != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.PayAmount) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("PayLimitDate" + ","); if (MasterEntity.PayLimitDate != SystemConfiguration.DateTimeDefaultValue) { MasterValue.Append(SysString.ToDBString(MasterEntity.PayLimitDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("Remark" + ")"); MasterValue.Append(SysString.ToDBString(MasterEntity.Remark) + ")"); //执行 int AffectedRows = 0; if (!this.sqlTransFlag) { AffectedRows = this.ExecuteNonQuery(MasterField.Append(MasterValue.ToString()).ToString()); } else { AffectedRows = sqlTrans.ExecuteNonQuery(MasterField.Append(MasterValue.ToString()).ToString()); } return(AffectedRows); } catch (BaseException E) { throw new BaseException(E.Message, E); } catch (Exception E) { throw new BaseException(FrameWorkMessage.GetAlertMessage((int)Message.CommonDBInsert), E); } }
/// <summary> /// 修改 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int Update(BaseEntity p_Entity) { try { SaleOrderCapDts MasterEntity = (SaleOrderCapDts)p_Entity; if (MasterEntity.ID == 0) { return(0); } //更新主表数据 StringBuilder UpdateBuilder = new StringBuilder(); UpdateBuilder.Append("UPDATE Sale_SaleOrderCapDts SET "); UpdateBuilder.Append(" ID=" + SysString.ToDBString(MasterEntity.ID) + ","); UpdateBuilder.Append(" MainID=" + SysString.ToDBString(MasterEntity.MainID) + ","); UpdateBuilder.Append(" Seq=" + SysString.ToDBString(MasterEntity.Seq) + ","); UpdateBuilder.Append(" CapName=" + SysString.ToDBString(MasterEntity.CapName) + ","); UpdateBuilder.Append(" ItemCode=" + SysString.ToDBString(MasterEntity.ItemCode) + ","); UpdateBuilder.Append(" PayStepTypeID=" + SysString.ToDBString(MasterEntity.PayStepTypeID) + ","); if (MasterEntity.PayPer != 0) { UpdateBuilder.Append(" PayPer=" + SysString.ToDBString(MasterEntity.PayPer) + ","); } else { UpdateBuilder.Append(" PayPer=null,"); } if (MasterEntity.PayAmount != 0) { UpdateBuilder.Append(" PayAmount=" + SysString.ToDBString(MasterEntity.PayAmount) + ","); } else { UpdateBuilder.Append(" PayAmount=null,"); } if (MasterEntity.PayLimitDate != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" PayLimitDate=" + SysString.ToDBString(MasterEntity.PayLimitDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" PayLimitDate=null,"); } UpdateBuilder.Append(" Remark=" + SysString.ToDBString(MasterEntity.Remark)); UpdateBuilder.Append(" WHERE " + "ID=" + SysString.ToDBString(MasterEntity.ID)); //执行 int AffectedRows = 0; if (!this.sqlTransFlag) { AffectedRows = this.ExecuteNonQuery(UpdateBuilder.ToString()); } else { AffectedRows = sqlTrans.ExecuteNonQuery(UpdateBuilder.ToString()); } return(AffectedRows); } catch (BaseException E) { throw new BaseException(E.Message, E); } catch (Exception E) { throw new BaseException(FrameWorkMessage.GetAlertMessage((int)Message.CommonDBUpdate), E); } }