在asp.net,如何实现订单处理后减少库存呢,更新数据库字段,只要点击购买就可以调用那个减少库存方法

在asp.net,如何实现订单处理后减少库存呢,更新数据库字段,只要点击购买就可以调用那个减少库存方法,第1张

一般订单分为 “订购单 ”和“出库单”,正常流程是订购单只是占用一个可订购库存,具体减库存是出库单生成后且执行称重出库才去减商品所在仓库的实际库存和订购单占用库存!

如果按照你说的做,在生成订单后就可以去执行更新数据库字段了

我的想法是将购买的东西用表保存,再将表保存到session[cart]中 ,点击购买时会有一件商品信息,假设为保存到DataTable中的tab点击购买按钮的click事件:if(session[cart]==null) //如果是第一次购买{ DataTable table=new DataTable() //动态生成表 DataColumn column1=new DataColumn("GoodsName",typeof(string))//动态生成列 DataColumn column2=new DataColumn("GoodsPrice",typeof(double)) DataColumn column3=new DataColumn("GoodsNumber",typeof(int))//假设我的表中只显示商品名称,商品价格,商品数量 table.Columns.add(column1) //将列添加到表中 table.Columns.add(column2)table.Columns.add(column3)DataRow row=table.newRow()row["GoodsName"]=tab.rows[0]["name"]//从tab表(只可能是一件商品)中拿到购买的商品名称列 row["GoodsPrice"]=tab.rows[0]["price"] //从tab表中拿到价格列row["GoodsNumber"]=1 //第一次购买默认数量就是1件 table.rows.add(row)//将row添加到表中 session["cart"]=table //将表放入到session中}else //第二次购买了{ DataTable shoppingCart=session["cart"] //从session中拿到table bool b=true for(DaraRow row in shoppingCart.Rows) { if(row["GoodsName"].toString()==tab[0]["name"].toString())//判断是否是同一件商品 { row["GoodsNumber"]=convert.toInt32(row["GoodsNumber"])+1 //将数量加上1 session["cart"]=shoppingCart //重新把表放入sessionb=false } } if(b) //没有相同的商品 { DataRow row=shoppingCart.newRow() row["GoodsName"]=tab[0]["Name"] row["GoodsPrice"]=tab[0]["price"] row["GoodsNumber"]=tab[0]["number"] shoppingCart.Rows.add(row)//添加新行 session["cart"]=shoppingCart //同样将表保存到session中 } response.redirect("cart.aspx") //跳到购物车界面去显示session中的表 }}没有验证,只是凭记忆敲的,如果有问题,我相信你自己也可以解决了;不过不知道符不符合你的要求。我习惯用Session保存表,也可以用集合。


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/308068.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-28
下一篇2023-04-28

发表评论

登录后才能评论

评论列表(0条)

    保存