ssm-购物车 更新

package com.jt.cart.controller;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.jt.cart.service.CartService;
import com.jt.common.po.Cart;
import com.jt.common.vo.SysResult;

@Controller
@RequestMapping("/cart")
public class CartController {
    @Autowired
    private CartService cartService;
    private static ObjectMapper objectMapper=new ObjectMapper();
    //根据用户id查询购物车信息
    @RequestMapping("/query/{userId}")
    @ResponseBody
    public SysResult findCartByUserId(@PathVariable Long userId){
        try {
            List<Cart> cartList=cartService.findCartByUserId(userId);
            return SysResult.oK(cartList);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return SysResult.build(201, "购物车信息查询失败");
    }
    @RequestMapping("/save")
    //实现购物车入库
    public SysResult saveCart(Cart cart){
        try {
            cartService.saveCart(cart);
            return SysResult.oK();
        } catch (Exception e) {
            // TODO: handle exception
        }
        return SysResult.build(201, "购物车新增失败");
    }
    @RequestMapping("/update/num")
    public SysResult updateCartNum(String cartJSON){
        try {
            Cart cart = objectMapper.readValue(cartJSON,Cart.class);
            cartService.updateCartNum(cart);
            return SysResult.oK();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return SysResult.build(201, "商品更新失败");
    }
}

package com.jt.cart.service;

import java.util.List;

import com.jt.common.po.Cart;

public interface CartService {

    List<Cart> findCartByUserId(Long userId);

    void saveCart(Cart cart);

    void updateCartNum(Cart cart);

}
package com.jt.cart.service;

import java.util.Date;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.jt.cart.mapper.CartMapper;
import com.jt.common.po.Cart;
@Service
public class CartServiceImpl implements CartService {
    @Autowired
    private CartMapper cartMapper;

    @Override
    public List<Cart> findCartByUserId(Long userId) {
        Cart cart=new Cart();
        cart.setUserId(userId);
        return cartMapper.select(cart);
    }

    /**
     * 根据userId和itemId判断数据库中是否有该购物车信息
     * 有
     *   数据库num+新num做更新操作
     * 没有数据
     *  应该插入数据库
     */
    /* (non-Javadoc)
     * @see com.jt.cart.service.CartService#saveCart(com.jt.common.po.Cart)
     */
    @Override
    public void saveCart(Cart cart) {       
        Cart cartDB=cartMapper.findCartByUI(cart);
        if(cartDB==null){
            System.out.println("insert cart");
            cart.setCreated(new Date());
            cart.setUpdated(cart.getCreated());
            cartMapper.insert(cart);
        }else{
            System.out.println("insert cart2");
            int num=cartDB.getNum()+cart.getNum();
            cartDB.setNum(num);
            cartDB.setUpdated(new Date());
            cartMapper.updateByPrimaryKeySelective(cartDB);
        }
    }

    @Override
    public void updateCartNum(Cart cart) {
        cart.setUpdated(new Date());
        cartMapper.updateCartNum(cart);
    }
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--namespace="它是映射文件的唯一标识"-相当于配置文件的主键 mapper接口调用方式,表明mapper接口/映射文件/表映射关系,用接口的全路径名称 -->
<mapper namespace="com.jt.cart.mapper.CartMapper">
    <!-- 修改购物车数量 -->
    <update id="updateCartNum">
        update tb_cart set num=#{num},updated=#{updated}
        where item_id=#{itemId} and user_id=#{userId}
    </update>
</mapper>
package com.jt.cart.mapper;

import org.apache.ibatis.annotations.Select;

import com.jt.common.mapper.SysMapper;
import com.jt.common.po.Cart;

public interface CartMapper extends SysMapper<Cart>{

    @Select("select * from tb_cart where item_id=#{itemId} and user_id=#{userId}")
    Cart findCartByUI(Cart cart);

    void updateCartNum(Cart cart);

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.选择 在任何一个单词前输入补字符号。按下Ctrl+Shift+右箭头 按下Ctrl+W扩展代码块的选择 按下C...
    幽灵小子阅读 1,660评论 1 0
  • 姐姐你想不想知道我喜不喜欢你 我喜欢你 @阿赵你竟然被小孩子撩了
    湘湘m阅读 826评论 3 5
  • 一、Android PopupWindow的使用 1、PopupView的基本使用 ①PopupWindow这个类...
    Yangxy_Lazy阅读 1,477评论 0 2
  • 文//缨子 最近,有许多人问我,为什么还没做好下一步的打算,就把多年的工作结束了? 整整二十年的光阴,我把自己人生...
    陌城锦书来阅读 601评论 5 3

友情链接更多精彩内容