Exemplo n.º 1
0
        private ItemBuyCapDts[] GetEntityDts()
        {
            int Num = 0;

            for (int i = 0; i < gridView1.RowCount; i++)
            {
                if (SysConvert.ToString(gridView1.GetRowCellValue(i, "PayStepTypeID")) != string.Empty)
                {
                    Num++;
                }
            }
            ItemBuyCapDts[] entityDts = new ItemBuyCapDts[Num];
            Num = 0;
            for (int j = 0; j < gridView1.RowCount; j++)
            {
                if (SysConvert.ToString(gridView1.GetRowCellValue(j, "PayStepTypeID")) != string.Empty)
                {
                    entityDts[Num]               = new ItemBuyCapDts();
                    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);
        }
Exemplo n.º 2
0
 /// <summary>
 /// 保存(传入事务处理)
 /// </summary>
 /// <param name="p_Entity"></param>
 /// <param name="p_BE"></param>
 /// <param name="sqlTrans"></param>
 public void RSave(ItemBuyForm p_Entity, BaseEntity[] p_BE, IDBTransAccess sqlTrans)
 {
     try
     {
         string sql = "DELETE FROM Buy_ItemBuyCapDts 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++)
         {
             ItemBuyCapDts entitydts = (ItemBuyCapDts)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);
     }
 }
Exemplo n.º 3
0
 /// <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 Buy_ItemBuyCapDts WHERE MainID=" + SysString.ToDBString(p_ID);
             sqlTrans.ExecuteNonQuery(sql);
             for (int i = 0; i < p_BE.Length; i++)
             {
                 ItemBuyCapDtsRule rule   = new ItemBuyCapDtsRule();
                 ItemBuyCapDts     entity = (ItemBuyCapDts)p_BE[i];
                 entity.MainID = p_ID;
                 entity.Seq    = i + 1;
                 rule.RAdd(entity, sqlTrans);
             }
             sql  = "UPDATE Buy_ItemBuyForm SET FKFlag=1";
             sql += " WHERE ID=" + SysString.ToDBString(p_ID);
             sqlTrans.ExecuteNonQuery(sql);
         }
     }
     catch (BaseException)
     {
         throw;
     }
     catch (Exception E)
     {
         throw new BaseException(E.Message);
     }
 }
Exemplo n.º 4
0
        /// <summary>
        /// 删除
        /// </summary>
        /// <param name="p_Entity">实体类</param>
        /// <returns>操作影响的记录行数</returns>
        public override int Delete(BaseEntity p_Entity)
        {
            try
            {
                ItemBuyCapDts MasterEntity = (ItemBuyCapDts)p_Entity;
                if (MasterEntity.ID == 0)
                {
                    return(0);
                }

                //删除主表数据
                string Sql = "";
                Sql = "DELETE FROM Buy_ItemBuyCapDts 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);
            }
        }
Exemplo n.º 5
0
        /// <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)
        {
            ItemBuyCapDts entity = (ItemBuyCapDts)p_BE;
            bool          ret    = false;
            string        sql    = string.Format(" SELECT {0} FROM {1} WHERE 1=1 AND {0}={2} AND {3}<>{4}", p_FieldName, ItemBuyCapDts.TableName, SysString.ToDBString(p_FieldValue), "ID", entity.ID);
            DataTable     dt     = p_sqlTrans.Fill(sql);

            if (dt.Rows.Count != 0)
            {
                ret = true;
            }

            return(ret);
        }
Exemplo n.º 6
0
        /// <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++)
            {
                ItemBuyCapDts entitydts = (ItemBuyCapDts)p_BE[i];
                if (entitydts.ID != 0)
                {
                    outstr += "," + entitydts.ID;
                }
            }
            return(outstr);
        }
Exemplo n.º 7
0
 /// <summary>
 /// 删除
 /// </summary>
 /// <param name="p_BE">要删除的实体</param>
 /// <param name="sqlTrans">事务类</param>
 public void RDelete(BaseEntity p_BE, IDBTransAccess sqlTrans)
 {
     try
     {
         this.CheckCorrect(p_BE);
         ItemBuyCapDts    entity  = (ItemBuyCapDts)p_BE;
         ItemBuyCapDtsCtl control = new ItemBuyCapDtsCtl(sqlTrans);
         control.Delete(entity);
     }
     catch (BaseException)
     {
         throw;
     }
     catch (Exception E)
     {
         throw new BaseException(E.Message);
     }
 }
Exemplo n.º 8
0
 /// <summary>
 /// 新增(传入事务处理)
 /// </summary>
 /// <param name="p_BE">要新增的实体</param>
 /// <param name="sqlTrans">事务类</param>
 public void RAdd(BaseEntity p_BE, IDBTransAccess sqlTrans)
 {
     try
     {
         this.CheckCorrect(p_BE);
         ItemBuyCapDts    entity  = (ItemBuyCapDts)p_BE;
         ItemBuyCapDtsCtl control = new ItemBuyCapDtsCtl(sqlTrans);
         entity.ID = (int)EntityIDTable.GetID((long)SysEntity.Buy_ItemBuyCapDts, sqlTrans);
         control.AddNew(entity);
     }
     catch (BaseException)
     {
         throw;
     }
     catch (Exception E)
     {
         throw new BaseException(E.Message);
     }
 }
Exemplo n.º 9
0
 /// <summary>
 /// 检查将要操作的数据是否符合业务规则
 /// </summary>
 /// <param name="p_BE"></param>
 private void CheckCorrect(BaseEntity p_BE)
 {
     ItemBuyCapDts entity = (ItemBuyCapDts)p_BE;
 }
Exemplo n.º 10
0
        /// <summary>
        /// 保存资金明细(传入事务处理)
        /// </summary>
        /// <param name="p_BE">要新增的实体</param>
        /// <param name="sqlTrans">事务类</param>
        public void RSaveBuyCap(ItemBuyForm p_BEMain, IDBTransAccess sqlTrans)
        {
            try
            {
                string sql = string.Empty;
                sql = "SELECT * FROM Buy_ItemBuyCapDts 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 FROM Buy_ItemBuyFormDts WHERE MainID=" + p_BEMain.ID + " GROUP BY ItemCode";
                DataTable dtBuyDts = sqlTrans.Fill(sql);//采购单品种明细



                //根据不同品种生成独立的付款明细
                ItemBuyCapDts[] entityDts = new ItemBuyCapDts[dtPayMethodDts.Rows.Count * dtBuyDts.Rows.Count];//初始化资金明细实体数组
                int             ci        = 0;
                for (int i = 0; i < dtPayMethodDts.Rows.Count; i++)
                {
                    for (int m = 0; m < dtBuyDts.Rows.Count; m++)//多个品种生成独立的资金计划
                    {
                        entityDts[ci] = new ItemBuyCapDts();
                        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.FormDate.AddDays(SysConvert.ToInt32(dtPayMethodDts.Rows[i]["DelayDayNum"])).Date;    //合同日延后多少天
                            break;

                        case (int)EnumPayDateType.依据发货日:    //备注下发货日;读取默认交期;后续发货后回填实际日期
                            entityDts[ci].Remark       = "根据发货日";
                            entityDts[ci].PayLimitDate = p_BEMain.ReqDate.AddDays(SysConvert.ToInt32(dtPayMethodDts.Rows[i]["DelayDayNum"])).Date;
                            break;
                        }

                        entityDts[ci].ItemCode  = dtBuyDts.Rows[m]["ItemCode"].ToString();
                        entityDts[ci].PayAmount = SysConvert.ToDecimal(dtBuyDts.Rows[m]["Amount"]) * entityDts[ci].PayPer;//付款金额
                        ci++;
                    }
                }
                this.RSave(p_BEMain, entityDts, sqlTrans);//保存明细
            }
            catch (BaseException)
            {
                throw;
            }
            catch (Exception E)
            {
                throw new BaseException(E.Message);
            }
        }
Exemplo n.º 11
0
        /// <summary>
        /// 新增
        /// </summary>
        /// <param name="p_Entity">实体类</param>
        /// <returns>操作影响的记录行数</returns>
        public override int AddNew(BaseEntity p_Entity)
        {
            try
            {
                ItemBuyCapDts MasterEntity = (ItemBuyCapDts)p_Entity;
                if (MasterEntity.ID == 0)
                {
                    return(0);
                }

                //新增主表数据
                StringBuilder MasterField = new StringBuilder();
                StringBuilder MasterValue = new StringBuilder();
                MasterField.Append("INSERT INTO Buy_ItemBuyCapDts(");
                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("ItemCode" + ",");
                MasterValue.Append(SysString.ToDBString(MasterEntity.ItemCode) + ",");
                MasterField.Append("CapName" + ",");
                MasterValue.Append(SysString.ToDBString(MasterEntity.CapName) + ",");
                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);
            }
        }
Exemplo n.º 12
0
        /// <summary>
        /// 修改
        /// </summary>
        /// <param name="p_Entity">实体类</param>
        /// <returns>操作影响的记录行数</returns>
        public override int Update(BaseEntity p_Entity)
        {
            try
            {
                ItemBuyCapDts MasterEntity = (ItemBuyCapDts)p_Entity;
                if (MasterEntity.ID == 0)
                {
                    return(0);
                }

                //更新主表数据
                StringBuilder UpdateBuilder = new StringBuilder();
                UpdateBuilder.Append("UPDATE Buy_ItemBuyCapDts SET ");
                UpdateBuilder.Append(" ID=" + SysString.ToDBString(MasterEntity.ID) + ",");
                UpdateBuilder.Append(" MainID=" + SysString.ToDBString(MasterEntity.MainID) + ",");
                UpdateBuilder.Append(" Seq=" + SysString.ToDBString(MasterEntity.Seq) + ",");
                UpdateBuilder.Append(" ItemCode=" + SysString.ToDBString(MasterEntity.ItemCode) + ",");
                UpdateBuilder.Append(" CapName=" + SysString.ToDBString(MasterEntity.CapName) + ",");
                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);
            }
        }