refactor(pricing): 重构券码使用记录相关接口和映射

- 移除了 VoucherUsageController 中的 Swagger 注解
- 更新了 PriceVoucherUsageRecordMapper 中的 SQL 查询
- 新增了 PriceVoucherUsageRecordMapper.xml 文件,用于定义分页查询
This commit is contained in:
2025-09-16 16:43:07 +08:00
parent ce3f7aae1e
commit 7cfcc44531
2 changed files with 19 additions and 28 deletions

View File

@@ -1,14 +1,11 @@
package com.ycwl.basic.pricing.controller;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ycwl.basic.common.ApiResponse;
import com.ycwl.basic.utils.ApiResponse;
import com.ycwl.basic.pricing.dto.req.VoucherUsageHistoryReq;
import com.ycwl.basic.pricing.dto.resp.VoucherUsageRecordResp;
import com.ycwl.basic.pricing.dto.resp.VoucherUsageStatsResp;
import com.ycwl.basic.pricing.service.IVoucherUsageService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.*;
@@ -22,13 +19,11 @@ import java.util.List;
@RestController
@RequestMapping("/api/pricing/voucher/usage")
@RequiredArgsConstructor
@Tag(name = "券码使用记录管理", description = "券码使用历史和统计API")
public class VoucherUsageController {
private final IVoucherUsageService voucherUsageService;
@PostMapping("/history")
@Operation(summary = "分页查询券码使用记录")
public ApiResponse<Page<VoucherUsageRecordResp>> getUsageHistory(@RequestBody VoucherUsageHistoryReq req) {
try {
Page<VoucherUsageRecordResp> result = voucherUsageService.getUsageHistory(req);
@@ -38,11 +33,10 @@ public class VoucherUsageController {
return ApiResponse.fail("查询失败: " + e.getMessage());
}
}
@GetMapping("/{voucherCode}/records")
@Operation(summary = "获取指定券码的使用记录")
public ApiResponse<List<VoucherUsageRecordResp>> getRecordsByCode(
@Parameter(description = "券码") @PathVariable String voucherCode) {
@PathVariable String voucherCode) {
try {
List<VoucherUsageRecordResp> records = voucherUsageService.getUsageRecordsByCode(voucherCode);
return ApiResponse.success(records);
@@ -51,11 +45,10 @@ public class VoucherUsageController {
return ApiResponse.fail("查询失败: " + e.getMessage());
}
}
@GetMapping("/{voucherCode}/stats")
@Operation(summary = "获取券码使用统计信息")
public ApiResponse<VoucherUsageStatsResp> getUsageStats(
@Parameter(description = "券码") @PathVariable String voucherCode) {
@PathVariable String voucherCode) {
try {
VoucherUsageStatsResp stats = voucherUsageService.getUsageStats(voucherCode);
if (stats == null) {
@@ -67,12 +60,11 @@ public class VoucherUsageController {
return ApiResponse.fail("查询失败: " + e.getMessage());
}
}
@GetMapping("/user/{faceId}/scenic/{scenicId}")
@Operation(summary = "获取用户在指定景区的券码使用记录")
public ApiResponse<List<VoucherUsageRecordResp>> getUserUsageRecords(
@Parameter(description = "用户faceId") @PathVariable Long faceId,
@Parameter(description = "景区ID") @PathVariable Long scenicId) {
@PathVariable Long faceId,
@PathVariable Long scenicId) {
try {
List<VoucherUsageRecordResp> records = voucherUsageService.getUserUsageRecords(faceId, scenicId);
return ApiResponse.success(records);
@@ -81,11 +73,10 @@ public class VoucherUsageController {
return ApiResponse.fail("查询失败: " + e.getMessage());
}
}
@GetMapping("/batch/{batchId}/stats")
@Operation(summary = "获取批次券码使用统计信息")
public ApiResponse<List<VoucherUsageStatsResp>> getBatchUsageStats(
@Parameter(description = "批次ID") @PathVariable Long batchId) {
@PathVariable Long batchId) {
try {
List<VoucherUsageStatsResp> statsList = voucherUsageService.getBatchUsageStats(batchId);
return ApiResponse.success(statsList);

View File

@@ -102,13 +102,13 @@ public interface PriceVoucherUsageRecordMapper extends BaseMapper<PriceVoucherUs
* @return 分页结果
*/
@Select("<script>" +
"SELECT * FROM price_voucher_usage_record WHERE deleted = 0 " +
"<if test='batchId != null'>AND batch_id = #{batchId}</if> " +
"<if test='voucherCode != null and voucherCode != \"\"'>AND voucher_code LIKE CONCAT('%', #{voucherCode}, '%')</if> " +
"<if test='faceId != null'>AND face_id = #{faceId}</if> " +
"<if test='scenicId != null'>AND scenic_id = #{scenicId}</if> " +
"<if test='startTime != null'>AND use_time >= #{startTime}</if> " +
"<if test='endTime != null'>AND use_time <= #{endTime}</if> " +
"SELECT * FROM price_voucher_usage_record WHERE deleted = 0" +
"<if test='batchId != null'>AND batch_id = #{batchId}</if>" +
"<if test=\"voucherCode != null and voucherCode.length() > 0\">AND voucher_code LIKE CONCAT('%', #{voucherCode}, '%')</if>" +
"<if test=\"faceId != null\">AND face_id = #{faceId}</if>" +
"<if test=\"scenicId != null\">AND scenic_id = #{scenicId}</if>" +
"<if test=\"startTime != null\">AND use_time >= #{startTime}</if>" +
"<if test=\"endTime != null\">AND use_time &lt;= #{endTime}</if>" +
"ORDER BY use_time DESC" +
"</script>")
Page<PriceVoucherUsageRecord> selectPageWithConditions(Page<PriceVoucherUsageRecord> page,