(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); }
|