[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]商城优惠券的处理方式。

上一篇:[备忘]jQuery PageBeforeShow Event Binding Multiple Times,事件触发多次
下一篇:[转帖]java实现简单的缓存cache,

添加日期:2015/4/6 21:48:18 快速返回   返回列表 阅读2518次
(1)用户拥有的优惠券,大概有以下字段:


@Id
    @Column("id")    
    private int id;
        
    /**
     * 优惠券编号.
     */
    @Column("coupon_no")    
    private String couponNo;
        
    /**
     * 面值.
     */
    @Column("face_value")    
    private int faceValue;
        
    /**
     * 需消费金额.
     */
    @Column("need_money")    
    private int needMoney;
        
    /**
     * 有效期From.
     */
    @Column("valid_date_from")    
    private java.util.Date validDateFrom;
        
    /**
     * 有效期To.
     */
    @Column("valid_date_to")    
    private java.util.Date validDateTo;
    
    /**
     * 用户ID.
     */
    @Column("user_id")    
    private int userId;
    
    /**
     * 是否使用.
     */
    @Column("isUsed")    
    private int isUsed;
        
    /**
     * 逻辑删除Flag.
     */
    @Column("delete_flag")
    private int deleteFlag;


编号无所谓,不重复即可,简单的方法就是用id,前面补0,比如补8个0什么的。

(2)提交订单时,显示可用的优惠券,大概逻辑如下:


        // 用户ID
        int userId = CommonUtil.getShopLoginUserId();

        // 拼接条件
        SqlExpressionGroup group = Cnd.exps("userId", "=", userId);

        // 未使用,未删除,已开始,未过期的。
        Date now = new Date();
        group = group.and("deleteFlag", "=", 0).and("isUsed", "=", 0).and("validDateTo", ">", now).and("validDateFrom", "<", now);

        // 当前商品金额>=所需消费金额
        group = group.and("needMoney", "<=", productTotalPrice.doubleValue());

        // 查询,按到期时间升序
        return this.dao().query(ShopUsersCoupon.class, Cnd.where(group).asc("validDateTo"));



(3)用户选择某个优惠券,提交订单。
<1>用一个单独的表,记录订单使用的优惠券ID
<2>优惠券,修改为已使用状态。

(4)取消订单时,将使用的优惠券改为未使用状态,(爱过期就过期,不管)

(5)我的优惠券里,可分别显示:未使用,已使用,已过期,已删除
大概逻辑如下:


        // 用户ID
        int userId = CommonUtil.getShopLoginUserId();

        // 拼接条件
        SqlExpressionGroup group = Cnd.exps("userId", "=", userId);

        // 0:可用的,1:已使用,2:已过期的,3:删除的
        if (type == 0) {
            // 可用的:未使用,未删除,未过期的。
            group = group.and("deleteFlag", "=", 0).and("isUsed", "=", 0).and("validDateTo", ">", new Date());
        } else if (type == 1) {
            // 已使用:一定是未删除的,是否过期不管
            group = group.and("isUsed", "=", 1);
        } else if (type == 2) {
            // 已过期:未使用,未删除,但是过期了。
            group = group.and("isUsed", "=", 0).and("deleteFlag", "=", 0).and("validDateTo", "<", new Date());
        } else if (type == 3) {
            // 已删除:一定是未使用的(未使用的才提供删除功能),是否过期不管
            group = group.and("deleteFlag", "=", 1);
        }

 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved