zoukankan      html  css  js  c++  java
  • List泛型Add后,所有值都是最后一次Add的结果 解决方法

    public List<VoucherEntryEntity> AnalyseVoucherEntry(DataTable voucherentry)
            {

                VoucherEntryEntity voucherentryentity = new VoucherEntryEntity();
                List<VoucherEntryEntity> listVoucherEntity = new List<VoucherEntryEntity>();
                for (int i = 0; i < voucherentry.Rows.Count;i++ )
                {
                    voucherentryentity.FBrNo = voucherentry.Rows[i]["FBrNo"].ToString();
                    voucherentryentity.FExplanation = voucherentry.Rows[i]["FExplanation"].ToString();
                    voucherentryentity.FAccountID = Convert.ToInt32(voucherentry.Rows[i]["FAccountID"]);
                    voucherentryentity.FDetailID = Convert.ToInt32(voucherentry.Rows[i]["FDetailID"]);
                    voucherentryentity.FCurrencyID = Convert.ToInt32(voucherentry.Rows[i]["FCurrencyID"]);
                    voucherentryentity.FExchangeRate = float.Parse(voucherentry.Rows[i]["FExchangeRate"].ToString());
                    voucherentryentity.FDC = Convert.ToInt32(voucherentry.Rows[i]["FDC"]);
                    voucherentryentity.FAmountFor = Convert.ToDecimal(voucherentry.Rows[i]["FAmountFor"]);
                    voucherentryentity.FAmount = Convert.ToDecimal(voucherentry.Rows[i]["FAmount"]);
                    voucherentryentity.FQuantity = float.Parse(voucherentry.Rows[i]["FQuantity"].ToString());
                    voucherentryentity.FMeasureUnitID = Convert.ToInt32(voucherentry.Rows[i]["FMeasureUnitID"]);
                    voucherentryentity.FUnitPrice = float.Parse(voucherentry.Rows[i]["FUnitPrice"].ToString());
                    voucherentryentity.FInternalInd = voucherentry.Rows[i]["FInternalInd"].ToString();
                    voucherentryentity.FAccountID2 = Convert.ToInt32(voucherentry.Rows[i]["FAccountID2"]);
                    voucherentryentity.FSettleTypeID = Convert.ToInt32(voucherentry.Rows[i]["FSettleTypeID"]);
                    voucherentryentity.FSettleNo = voucherentry.Rows[i]["FSettleNo"].ToString();
                    voucherentryentity.FTransNo = voucherentry.Rows[i]["FTransNo"].ToString();
                    voucherentryentity.FCashFlowItem = Convert.ToInt32(voucherentry.Rows[i]["FCashFlowItem"]);
                    voucherentryentity.FTaskID = Convert.ToInt32(voucherentry.Rows[i]["FTaskID"]);
                    voucherentryentity.FResourceID = Convert.ToInt32(voucherentry.Rows[i]["FResourceID"]);
                    listVoucherEntity.Add(voucherentryentity);
                }
                return listVoucherEntity;
            }

    添加多条数据时,所有的值都是最后一次的结果。

    原来在.net中,list 在ADD时,每次保留一个它的引用,所以要把VoucherEntryEntity voucherentryentity = new VoucherEntryEntity();
    放到for循环中去才可以避免ADD后的值不会重复,也就是每循环一次,VoucherEntryEntity 就要new 一次.

     

     

    public List<VoucherEntryEntity> AnalyseVoucherEntry(DataTable voucherentry)
            {

                
                List<VoucherEntryEntity> listVoucherEntity = new List<VoucherEntryEntity>();
                for (int i = 0; i < voucherentry.Rows.Count;i++ )
                {

                    VoucherEntryEntity voucherentryentity = new VoucherEntryEntity();
                    voucherentryentity.FBrNo = voucherentry.Rows[i]["FBrNo"].ToString();
                    voucherentryentity.FExplanation = voucherentry.Rows[i]["FExplanation"].ToString();
                    voucherentryentity.FAccountID = Convert.ToInt32(voucherentry.Rows[i]["FAccountID"]);
                    voucherentryentity.FDetailID = Convert.ToInt32(voucherentry.Rows[i]["FDetailID"]);
                    voucherentryentity.FCurrencyID = Convert.ToInt32(voucherentry.Rows[i]["FCurrencyID"]);
                    voucherentryentity.FExchangeRate = float.Parse(voucherentry.Rows[i]["FExchangeRate"].ToString());
                    voucherentryentity.FDC = Convert.ToInt32(voucherentry.Rows[i]["FDC"]);
                    voucherentryentity.FAmountFor = Convert.ToDecimal(voucherentry.Rows[i]["FAmountFor"]);
                    voucherentryentity.FAmount = Convert.ToDecimal(voucherentry.Rows[i]["FAmount"]);
                    voucherentryentity.FQuantity = float.Parse(voucherentry.Rows[i]["FQuantity"].ToString());
                    voucherentryentity.FMeasureUnitID = Convert.ToInt32(voucherentry.Rows[i]["FMeasureUnitID"]);
                    voucherentryentity.FUnitPrice = float.Parse(voucherentry.Rows[i]["FUnitPrice"].ToString());
                    voucherentryentity.FInternalInd = voucherentry.Rows[i]["FInternalInd"].ToString();
                    voucherentryentity.FAccountID2 = Convert.ToInt32(voucherentry.Rows[i]["FAccountID2"]);
                    voucherentryentity.FSettleTypeID = Convert.ToInt32(voucherentry.Rows[i]["FSettleTypeID"]);
                    voucherentryentity.FSettleNo = voucherentry.Rows[i]["FSettleNo"].ToString();
                    voucherentryentity.FTransNo = voucherentry.Rows[i]["FTransNo"].ToString();
                    voucherentryentity.FCashFlowItem = Convert.ToInt32(voucherentry.Rows[i]["FCashFlowItem"]);
                    voucherentryentity.FTaskID = Convert.ToInt32(voucherentry.Rows[i]["FTaskID"]);
                    voucherentryentity.FResourceID = Convert.ToInt32(voucherentry.Rows[i]["FResourceID"]);
                    listVoucherEntity.Add(voucherentryentity);
                }
                return listVoucherEntity;
            }

  • 相关阅读:
    Python 学习日记 第七天
    Python 学习日记 第六天
    Python 学习日记 第五天
    Python 学习日记 第四天
    Redis 中的数据类型及基本操作
    Asp.net mvc 中View 的呈现(二)
    Asp.net mvc 中View的呈现(一)
    Asp.net mvc 中Action 方法的执行(三)
    Asp.net mvc 中Action 方法的执行(二)
    Asp.net mvc 中Action 方法的执行(一)
  • 原文地址:https://www.cnblogs.com/htys/p/3168848.html
Copyright © 2011-2022 走看看