|
|
|
|
@ -1,5 +1,6 @@
|
|
|
|
|
package cn.iocoder.yudao.module.promotion.dal.mysql.seckill.seckillactivity;
|
|
|
|
|
|
|
|
|
|
import cn.hutool.core.lang.Assert;
|
|
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
|
|
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
|
|
|
|
|
@ -39,13 +40,14 @@ public interface SeckillActivityMapper extends BaseMapperX<SeckillActivityDO> {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 更新活动库存
|
|
|
|
|
* 更新活动库存(减少)
|
|
|
|
|
*
|
|
|
|
|
* @param id 活动编号
|
|
|
|
|
* @param count 扣减的库存数量
|
|
|
|
|
* @param count 扣减的库存数量(正数)
|
|
|
|
|
* @return 影响的行数
|
|
|
|
|
*/
|
|
|
|
|
default int updateStock(Long id, int count) {
|
|
|
|
|
default int updateStockDecr(Long id, int count) {
|
|
|
|
|
Assert.isTrue(count > 0);
|
|
|
|
|
return update(null, new LambdaUpdateWrapper<SeckillActivityDO>()
|
|
|
|
|
.eq(SeckillActivityDO::getId, id)
|
|
|
|
|
.gt(SeckillActivityDO::getTotalStock, 0)
|
|
|
|
|
@ -53,6 +55,21 @@ public interface SeckillActivityMapper extends BaseMapperX<SeckillActivityDO> {
|
|
|
|
|
.setSql("total_stock = total_stock - " + count));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 更新活动库存(增加)
|
|
|
|
|
*
|
|
|
|
|
* @param id 活动编号
|
|
|
|
|
* @param count 增加的库存数量(正数)
|
|
|
|
|
* @return 影响的行数
|
|
|
|
|
*/
|
|
|
|
|
default int updateStockIncr(Long id, int count) {
|
|
|
|
|
Assert.isTrue(count > 0);
|
|
|
|
|
return update(null, new LambdaUpdateWrapper<SeckillActivityDO>()
|
|
|
|
|
.eq(SeckillActivityDO::getId, id)
|
|
|
|
|
.setSql("stock = stock - " + count)
|
|
|
|
|
.setSql("total_stock = total_stock + " + count));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
default PageResult<SeckillActivityDO> selectPage(AppSeckillActivityPageReqVO pageReqVO, Integer status) {
|
|
|
|
|
return selectPage(pageReqVO, new LambdaQueryWrapperX<SeckillActivityDO>()
|
|
|
|
|
.eqIfPresent(SeckillActivityDO::getStatus, status)
|
|
|
|
|
@ -62,6 +79,7 @@ public interface SeckillActivityMapper extends BaseMapperX<SeckillActivityDO> {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 查询出指定 spuId 的 spu 参加的活动最接近现在的一条记录。多个的话,一个 spuId 对应一个最近的活动编号
|
|
|
|
|
*
|
|
|
|
|
* @param spuIds spu 编号
|
|
|
|
|
* @param status 状态
|
|
|
|
|
* @return 包含 spuId 和 activityId 的 map 对象列表
|
|
|
|
|
|