我想在數據表上工作,以便將新值與現有數據表進行比較(如果可用),數量將相加,但如果沒有,則會在數據表中添加一行。比較數據表中的值
if (HttpContext.Current.Session["Cart"] != null)
{
DataTable shoppingcart = (DataTable)HttpContext.Current.Session["Cart"];
for (int i = 0; i < shoppingcart.Rows.Count; i++)
{
String checktitle = shoppingcart.Rows[i]["Title"].ToString();
if (title == checktitle)
{
//do something
}
else
{
ShoppingCart.DataSource = cart.cartrow(shoppingcart);
ShoppingCart.DataBind();
}
}
}
else
{
HttpContext.Current.Session["Cart"] = cart.shoppingCart();
ShoppingCart.DataSource = cart.shoppingCart();
ShoppingCart.DataBind();
}
}
但不知何故。我無法設法增加它的數量。它每次都會創建一個新的行。 感謝您的意見。 這是我使用添加行或添加表
String title { get; set; }
decimal price { get; set; }
int quantity { get; set; }
DataTable CartTable;
DataRow tableRow;
public cart(String _title, decimal _price)
{
title = _title;
price = _price;
}
public DataTable shoppingCart()
{
CartTable = new DataTable("cart");
CartTable.Columns.Add("ID", typeof(Int32));
CartTable.Columns["ID"].AutoIncrement = true;
CartTable.Columns["ID"].AutoIncrementSeed = 1;
CartTable.Columns.Add("Title");
CartTable.Columns.Add("Price");
CartTable.Columns.Add("quantity");
tableRow = CartTable.NewRow();
tableRow["Title"] = title;
tableRow["Price"] = price;
tableRow["quantity"] = quantity;
CartTable.Rows.Add(tableRow);
return CartTable;
}
public DataTable cartrow(DataTable _cart)
{
tableRow = _cart.NewRow();
tableRow["Title"] = title;
tableRow["Price"] = price;
tableRow["quantity"] = quantity;
_cart.Rows.Add(tableRow);
return _cart;
}
您的代碼不告訴你在問什麼。你在哪裏比較價值,添加一個數量,並創建一個新的行? –
對不起,我是編程新手。我創建了一個類來運行我添加的行和表 – eugene