关于一个计算总价的问题

wenmi 2010-08-18 11:16:33
public partial class Admin_Checkmoney : System.Web.UI.Page
{
DataTable orlist = new DataTable("cart");
DataRow prorow;
public Double oTotal = 0.0000;

protected void Page_Load(object sender, EventArgs e)
{
showorder();
}

private static string dbconnect()
{
return ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
}

protected void showorder()
{
if (Session["orderlist"] == null)
{
DataColumn[] keys = new DataColumn[1];
DataColumn a1 = new DataColumn("menu_id", typeof(string));
DataColumn a2 = new DataColumn("menu_name", typeof(string));
DataColumn a3 = new DataColumn("menu_price", typeof(decimal));
DataColumn a4 = new DataColumn("quantity", typeof(string));
DataColumn a5 = new DataColumn("subtotal", typeof(decimal));
orlist.Columns.Add(a1);
orlist.Columns.Add(a2);
orlist.Columns.Add(a3);
orlist.Columns.Add(a4);
orlist.Columns.Add(a5);
keys[0] = a1;
orlist.PrimaryKey = keys;
Session["orderlist"] = orlist;
}
else
{
orlist = (DataTable)Session["orderlist"];
}

}

protected void checking(object sender, EventArgs e)
{
bool same = true;
SqlCommand cmd = new SqlCommand("checkout", new SqlConnection(dbconnect()));
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@o_name", SqlDbType.VarChar, 50);
cmd.Parameters["@o_name"].Value = this.oname.Text;
cmd.Connection.Open();
SqlDataReader dr = cmd.ExecuteReader();
if (!same)
{
if (dr.Read())
{
prorow = orlist.NewRow();
prorow["menu_id"] = dr["menu_id"].ToString();
prorow["menu_name"] = dr["menu_name"].ToString();
prorow["menu_price"] = dr["menu_price"].ToString();
prorow["quantity"] = dr["quantity"].ToString();
prorow["subtotal"] = Convert.ToInt32(dr[3].ToString()) * Convert.ToDecimal(dr[2].ToString());
orlist.Rows.Add(prorow);
}
}
Session["orderlist"] = orlist;
this.checkout.DataSource = dr;
this.checkout.DataBind();
cmd.Connection.Close();
}

protected void totalcount(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.Footer)
{
for (int i = 0; i < orlist.Rows.Count; i++)
{
oTotal += Convert.ToDouble(orlist.Rows[i][4]);
}
}
}
}
运行后 <%=oTotal %>的值是0,请各位帮我看看哪里出问题了啊。。
...全文
104 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
wuyq11 2010-08-18
  • 打赏
  • 举报
回复
if(!IsPostBack)showorder();
public DataTable orlist
{
//viewstate保存
}
new DataTable().Compute("sum()","");
wenmi 2010-08-18
  • 打赏
  • 举报
回复
不得行。。还是样的0
beyond_me21 2010-08-18
  • 打赏
  • 举报
回复
错了,应该是
oTotal += Convert.ToDouble(orlist.Rows[i][4].ToString());
beyond_me21 2010-08-18
  • 打赏
  • 举报
回复
oTotal += Convert.ToDouble(orlist.Rows[i][4].Text.ToString());

62,073

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧