购物车功能后端实现案例

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

表结构:

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

查询购物车消息功能:

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

controller层代码:

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

service层代码:

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

mapper和mappers:

List<Cart> selectCartByUserid(String userId);
-------------------------------------------------
<!--select查询我的购物车-->
    <select id="selectCartByUserid" resultType="Cart">
        select * from t_cart where user_id=#{userId};
    </select>

新增商品到购物车功能:

当你在浏览某件商品,需要把他加入购物车,这时就会有两种情况:
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 id="selectCartByUseridAndProductid" resultType="Cart">
        select * from t_cart where user_id=#{userId}
        and product_id=#{productId};
    </select>
    <!--更新num-->
    <update id="updateNumByUseridAndProductid">
        update t_cart set num=#{num} where user_id=#{userId}
        and product_id=#{productId};
    </update>
    <!--新增购物车-->
    <insert id="insertCart">
        insert into t_cart (
        user_id,product_id,num,
        product_name,product_price,product_image) values (
        #{userId},#{productId},#{num},
        #{productName},#{productPrice},#{productImage}
        )
    </insert>

修改购物车里的商品数量:

这里做的很简单了,就是去修改表里的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);
  -----------------------------------------------
     <!--更新num-->
    <update id="updateNumByUseridAndProductid">
        update t_cart set num=#{num} where user_id=#{userId}
        and product_id=#{productId};
    </update>

删除商品再购物车中的信息:

这个更简单,就是删除数据库一条记录,如果再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 id="deleteCartByUseridAndProductid">
        delete from t_cart where user_id=#{userId}
        and product_id=#{productId};
    </delete>
  • 5
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牛像话

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值