购物车功能后端实现案例

您所在的位置:网站首页 购物程序代码 购物车功能后端实现案例

购物车功能后端实现案例

2023-09-04 18:56| 来源: 网络整理| 查看: 265

说明:案例使用的是ssm+springBoot+springCloud+redis

表结构:

通过用户id和商品id构建关系,所以一个user_id在表中会有多条。 在这里插入图片描述

查询购物车消息功能:

思路很简单,就是把用户id从前端传入进来后端,接收用户id,用此id去表里查数据,然后返回一个储存购物车对象的list给前端就可以。

controller层代码:

//根据userId查询用户的购物车list @RequestMapping("query") public List queryMyCarts(String userId){ return cartService.queryMyCarts(userId); }

service层代码:

//使用用户id查找用户加入购物车的商品 public List queryMyCarts(String userId) { return cartMapper.selectCartByUserid(userId); }

mapper和mappers:

List selectCartByUserid(String userId); ------------------------------------------------- select * from t_cart where user_id=#{userId}; 新增商品到购物车功能:

当你在浏览某件商品,需要把他加入购物车,这时就会有两种情况: 1.这个商品之前你已经把他添加到过购物车,所以这一次的添加,实际上是对一个数量的修改,属于update操作。我们需要更新表中对应商品的num值即可 2.此商品在购物车中没有,所以这个操作属于insert操作。我们需要对表进行一次插入操作。 因为这一次使用了微服务之间的调用,所以使用到了ribbon

启动类中:

@Bean @LoadBalanced public RestTemplate init(){ return new RestTemplate(); }

controller层:

//新增商品到我的购物车 @RequestMapping("save") public SysResult addCart(Cart cart){ try{ cartService.addCart(cart); return SysResult.ok(); }catch (Exception e){ e.printStackTrace(); return SysResult.build(201,"新增购物车失败",null); } }

service层:

@Autowired private RestTemplate template; public void addCart(Cart cart) {//这次从前端获取到的数据只有userId 和productId //通过数据查询从数据库查询已有,所以执行的是update操作 Cart existCart=cartMapper.selectCartByUseridAndProductid(cart); if(existCart!=null){ //说明购物车商品在表格中已存在的 //把已存在的商品num+新增商品num //update t_cart set num=num+#{num} 更新num功能中重新写sql //update t_cart set num=#{num} 更新num可以直接调用 cart.setNum(cart.getNum()+existCart.getNum()); cartMapper.updateNumByUseridAndProductid(cart); }else{//需要新增一个cart对象到数据库 //cart对象中只有userId productId num 没有productName productPrice productImage //RestTemplate 发送微服务调用 请求商品系统的单个商品查询功能 String url="http://productservice/product/manage/item/"+cart.getProductId(); Product p=template.getForObject(url, Product.class); if(p!=null){//说明商品系统查到了数据 cart.setProductName(p.getProductName()); cart.setProductPrice(p.getProductPrice()); cart.setProductImage(p.getProductImgurl()); cartMapper.insertCart(cart); }else{ throw new RuntimeException("从商品系统根本没查到商品数据"); } } }

mapper和mappers:

Cart selectCartByUseridAndProductid(Cart cart); void updateNumByUseridAndProductid(Cart cart); void insertCart(Cart cart); -------------------------------------------------- select * from t_cart where user_id=#{userId} and product_id=#{productId}; update t_cart set num=#{num} where user_id=#{userId} and product_id=#{productId}; insert into t_cart ( user_id,product_id,num, product_name,product_price,product_image) values ( #{userId},#{productId},#{num}, #{productName},#{productPrice},#{productImage} ) 修改购物车里的商品数量:

这里做的很简单了,就是去修改表里的num值。(后面这个是我的猜想,我也没有做过,大家可以看看对不对)还可以把它做到缓存里,当你每次修改完购物车信息,就可以把user_id+uuid+product_id生成一个key,把商品信息转换成一个json作为value,存入redis缓存中,同时把user_id+uuid+product_id存入cookie的value中,当用户下次再点击购物车,如果没有正在修改,则从缓存中查询数据。也可以做数据一致性。

controller层:

//购物车商品的更新 //接收到的num数量就是更新的最终数量 不要和旧数据相加 @RequestMapping("update") public SysResult updateNum(Cart cart){ //cart参数包含了 productId userId num try{ cartService.updateNum(cart); return SysResult.ok(); }catch (Exception e){ e.printStackTrace(); return SysResult.build(201,"更新num失败",null); } }

service层:

public void updateNum(Cart cart) { //持久层在新增购物车时完成了更新num的功能 cartMapper.updateNumByUseridAndProductid(cart); }

mapper和mappers:

void updateNumByUseridAndProductid(Cart cart); ----------------------------------------------- update t_cart set num=#{num} where user_id=#{userId} and product_id=#{productId}; 删除商品再购物车中的信息:

这个更简单,就是删除数据库一条记录,如果再redis中做了缓存,把缓存也一起删了就可以。

controller层:

@RequestMapping("delete") public SysResult deleteCart(Cart cart){ //cart中只包含2个数据 userId productId try{ cartService.deleteCart(cart); return SysResult.ok(); }catch (Exception e){ e.printStackTrace(); return SysResult.build(201,"删除购物车失败",null); } }

service层:

public void deleteCart(Cart cart) { cartMapper.deleteCartByUseridAndProductid(cart); }

mapper和mappers:

void deleteCartByUseridAndProductid(Cart cart); -------------------------------------------------- delete from t_cart where user_id=#{userId} and product_id=#{productId};


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3