购物车的存储过程学习

<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

从来没有接触过存储过程,为了这个项目写了几个存储过程。就当是学习了,呵呵,这个 购物车的存储过程中使用了Table(表),Cursor(游标)变量。

要求如下:

一个商品表[Ware],里面包含有的字段有ID,MarketPrice,MemberPrice,VipPrice等等,还一个会员 购物车[MemberCar]数据表。包括的有ID,MemberID,WareID,WareNum等等。现要求是能取得 购物车表里的所有数据和MarketPrice*WareNum(所有商品和)的总价钱,即有N件商品就获取这N件商品的总价钱而不是单一的价钱。本来在客户端里直接根据 购物车[MemberCar]表的数据读取商品表[Ware]里的数据,再用变量累加即可的。但问题却是, 购物车里的所有商品显示使用了分页显示。所以累加时就出问题,如果为了累加这些价钱而在分页循环显示后再加一个循环所有记录来累加价钱数据,这样不是不行,但效率就可想而知了!!!

现一个解决方法就是,重新构造一个 购物车表的镜像,但却多了商品的几个价钱总数字段。即MarketPrice*WareNum(单一商品)。从而读取 购物车时不是读取原来 购物车数据表,而是读取这个镜像数据表,并在读取时累加这些总价钱。

存储过程代码如下:
----#####################################################################################
----#过程作用:返回用户 购物车里的所有数据,并包含统计了商品的价钱(价钱=商品表的价格* 购物车表里的数量)
----#作者:死在水中的鱼
----#日期:2004年10月15日
----#####################################################################################
CREATEPROCEDUREMemberCar_Info@MemberIDINT AS
--使用此句才能保持客户端的数据
SETNOCOUNTON
DECLARE@Car_IDint,@Car_WareIDint,@Car_WareNumsmallINt
DECLARE@Car_TotalMemberPriceNumeric(8,2),@Car_TotalMarketPriceNumeric(8,2),@Car_TotalVipPriceNumeric(8,2)
--定义一个查询MemberCar表的游标变量。获取数据
DECLARECar_Cursor CursorFor
               SelectID,WareID,WareNumFrom[MemberCar]WhereMemberID=@MemberIDAndIsPay=0
--建立一个临时表变量
DECLARE@Car_TableTable (IDINT,
                                      WareIDINT,WareNumSmallINT,MarketPriceNumeric(8,2),MemberPriceNumeric(8,2),VipPriceNumeric(8,2))
--打开MemberCar表提取数据到临时变量
OPENCar_Cursor
FETCHNEXTFROMCar_CursorINTO@Car_ID,@Car_WareID,@Car_WareNum
WHILE@@FETCH_STATUS=0
BEGIN
    --取得商品的总市场价、总会员价和总VIP价
    Select@Car_TotalMarketPrice=MarketPrice*@Car_WareNum,@Car_TotalMemberPrice=MemberPrice*@Car_WareNum,@Car_TotalVipPrice=VipPrice*@Car_WareNumFrom[Ware]WhereID=@Car_WareID
   --添加进临时变量表
     INSERTINTO@Car_Table(ID,WareID,WareNum,MarketPrice,MemberPrice,VipPrice)Values(@Car_ID,@Car_WareID,@Car_WareNum,@Car_TotalMarketPrice,@Car_TotalMemberPrice,@Car_TotalVipPrice)
    --没有到表尾,继续提取数据到临时变量
     FETCHNEXTFROMCar_CursorINTO@Car_ID,@Car_WareID,@Car_WareNum
END
--关闭MemberCar的游标
CLOSECar_Cursor上一页 
<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值