• 购物车模块复用/浮点型商业运算精度丢失问题/NULLIF-Mybatis


    一、购物车模块复用

    主要是判断库存,以及购物车中每个商品状态、价格等包装

    //判断库存并返回处理后的结果
        private CartVo getCartVoLimit(Integer userId){
            CartVo cartVo = new CartVo();
            List<Cart> cartList = cartMapper.selectCartByUserId(userId);
    
            //用来装配CartProductVo
            List<CartProductVo> cartProductVoList = Lists.newArrayList();
            //购物车总价
            BigDecimal cartTotalPrice = new BigDecimal("0");
    
            if (CollectionUtils.isNotEmpty(cartList)){
                //遍历每一个购物车,计算购物车中的每个产品数量。总价,库存等,用CartProductVo封装
                for (Cart cartItem : cartList){
                    CartProductVo cartProductVo = new CartProductVo();
                    cartProductVo.setUserId(userId);
                    cartProductVo.setId(cartItem.getId());
                    cartProductVo.setProductId(cartItem.getProductId());
    
                    //cartProductVo.setQuantity();
                    //cartProductVo.setProductTotalPrice();
    
                    Product product = productMapper.selectByPrimaryKey(cartItem.getProductId());
                    if (product != null){
                        cartProductVo.setProductMainImage(product.getMainImage());
                        cartProductVo.setProductSubtitle(product.getSubtitle());
                        cartProductVo.setProductName(product.getName());
                        cartProductVo.setProductPrice(product.getPrice());
                        cartProductVo.setProductStatus(product.getStatus());
                        cartProductVo.setProductStock(product.getStock());
    
                        //判断库存
                        int buyLimitCount = 0;
                        if (product.getStock() >= cartItem.getQuantity()){
                            //库存充足
                            buyLimitCount = cartItem.getQuantity();
                            cartProductVo.setLimitQuantity(Const.Cart.LIMIT_NUM_SUCCESS);
                        }else {
                            //库存不足
                            buyLimitCount = product.getStock();
                            cartProductVo.setLimitQuantity(Const.Cart.LIMIT_NUM_FAIL);
    
                            //购物车更新库存
                            Cart updateCart = new Cart();
                            updateCart.setId(cartItem.getId());
                            updateCart.setQuantity(buyLimitCount);
                            cartMapper.updateByPrimaryKeySelective(updateCart);
                        }
    
                        cartProductVo.setQuantity(buyLimitCount);
                        //总价=产品价格*购物车该产品数量
                        cartProductVo.setProductTotalPrice(BigDecimalUtil.mul(product.getPrice().doubleValue(),
                                cartProductVo.getQuantity()));
                        cartProductVo.setProductChecked(cartItem.getChecked());
                    }
                    if (cartItem.getChecked() == Const.Cart.CHECKED){
                        //如果已经勾选,增加到整个的购物车总价中
                        cartTotalPrice = BigDecimalUtil.add(cartTotalPrice.doubleValue(),
                                cartProductVo.getProductTotalPrice().doubleValue());
                    }
                    cartProductVoList.add(cartProductVo);
                }
            }
    
            cartVo.setCartTotalPrice(cartTotalPrice);
            cartVo.setCartProductVoList(cartProductVoList);
            cartVo.setImageHost(PropertiesUtil.getProperty("ftp.server.http.prefix"));
            cartVo.setAllChecked(this.isAllChecked(userId));
            return cartVo;
        }

    二、浮点型商业运算精度丢失问题---使用BigDecimal

    package com.mmall.util;
    
    import java.math.BigDecimal;
    
    /**
     * @author GenshenWang.nomico
     * @date 2018/4/17.
     */
    public class BigDecimalUtil {
    
        private BigDecimalUtil(){
    
        }
    
        public static BigDecimal add(double v1, double v2){
            BigDecimal b1 = new BigDecimal(Double.toString(v1));
            BigDecimal b2 = new BigDecimal(Double.toString(v2));
            return b1.add(b2);
        }
    
        public static BigDecimal sub(double v1, double v2){
            BigDecimal b1 = new BigDecimal(Double.toString(v1));
            BigDecimal b2 = new BigDecimal(Double.toString(v2));
            return b1.subtract(b2);
        }
    
        public static BigDecimal mul(double v1, double v2){
            BigDecimal b1 = new BigDecimal(Double.toString(v1));
            BigDecimal b2 = new BigDecimal(Double.toString(v2));
            return b1.multiply(b2);
        }
    
        public static BigDecimal div(double v1, double v2){
            BigDecimal b1 = new BigDecimal(Double.toString(v1));
            BigDecimal b2 = new BigDecimal(Double.toString(v2));
            //保留两位小数,四舍五入
            return b1.divide(b2, 2, BigDecimal.ROUND_HALF_UP);
        }
    }

    三、IFNULL

      <select id="selectCartProductCount" parameterType="int" resultType="int">
        select IFNULL(sum(quantity),0) as count from mmall_cart where user_id = #{userId} and
      </select>
  • 相关阅读:
    JDBC获取数据库表字段信息
    No bean named 'springSecurityFilterChain' is defined
    VS 2010中对WPF4有哪些多点触摸支持?
    文件管理File类
    VS 2010 Beta2中WPF有哪些改进?
    WPF的实质
    C#中AppDomain.CurrentDomain.BaseDirectory与Application.StartupPath的区别
    VS 2010 Beta2中WPF与Silverlight的关键区别?
    C# 图片与byte[]之间以及byte[]与string之间的转换
    日期格式化{0:yyyyMMdd HH:mm:ss.fff}和{0:yyyyMMdd hh:mm:ss.fff}的区别
  • 原文地址:https://www.cnblogs.com/noaman/p/8871431.html
Copyright © 2020-2023  润新知