购物车功能后端实现案例 |
您所在的位置:网站首页 › 购物程序代码 › 购物车功能后端实现案例 |
说明:案例使用的是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 |