该程序在“数据网格视图”中显示数据库信息。 我需要将第1列中的所有数字相加,然后将第3列中的所有数字相加,然后将两个总和相乘。

此代码仅将最后一行的列1和列3相乘。 有什么建议么?

这是我第一次连接数据库,因此如果这看起来很愚蠢,我深表歉意。

                foreach (DataRow currentRow in itemDS.Tables[0].Rows)
                {
                    // add to data grid view
                    invoiceDataGridView.Rows.Add(currentRow[1].ToString(),   currentRow[2].ToString(), currentRow[3].ToString());

                    var itemQuant = Convert.ToDecimal(currentRow[1]);
                    var priceEach = Convert.ToDecimal(currentRow[3]);

                    decimal subTotal = itemQuant * priceEach;

                    subTotalOutput.Text = subTotal.ToString();
                }

===============>>#1 票数:0 已采纳

您的意思是您不确定如何在循环结构中保持连续运行吗? 如果是这样的话:

decimal total = 0; //declare outside the foreach

foreach (DataRow currentRow in itemDS.Tables[0].Rows)
                {
                    // add to data grid view
                    invoiceDataGridView.Rows.Add(currentRow[1].ToString(),   currentRow[2].ToString(), currentRow[3].ToString());

                    var itemQuant = Convert.ToDecimal(currentRow[1]);
                    var priceEach = Convert.ToDecimal(currentRow[3]);

                    decimal subTotal = itemQuant * priceEach;

                    total += subTotal;
                }

//do something with total here, after for each finishes

===============>>#2 票数:0

您可以使用linq求和。

var sum = itemDS.Tables[0].AsEnumerable().Sum(dr => dr.Field<int>("value"));

"value"将是itemDS中数据表的列名。 您必须在此处指定列名。

像上面的语句一样取下一列的总和。 加乘..

希望这可以帮助.. :)

  ask by Learnin2Code translate from so

未解决问题?本站智能推荐: