优化
This commit is contained in:
		| @ -0,0 +1,55 @@ | |||||||
|  | package cn.iocoder.yudao.module.member.controller.admin.customizeExcel; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageParam; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||||
|  | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
|  | import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | ||||||
|  | import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.business.vo.BusinessPageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.business.vo.BusinessRespVO; | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.customizeExcel.vo.OrderExcelVO; | ||||||
|  | import cn.iocoder.yudao.module.member.dal.dataobject.business.BusinessDO; | ||||||
|  | import cn.iocoder.yudao.module.member.service.business.BusinessService; | ||||||
|  | import cn.iocoder.yudao.module.member.service.customizeExcel.CustomizeExcelService; | ||||||
|  | import io.swagger.v3.oas.annotations.Operation; | ||||||
|  | import io.swagger.v3.oas.annotations.Parameter; | ||||||
|  | import io.swagger.v3.oas.annotations.tags.Tag; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.web.bind.annotation.GetMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RequestMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RequestParam; | ||||||
|  | import org.springframework.web.bind.annotation.RestController; | ||||||
|  |  | ||||||
|  | import javax.annotation.Resource; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  | import javax.validation.Valid; | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
|  | import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.EXPORT; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Tag(name = "管理后台 - 自定义表格导出") | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/member/export") | ||||||
|  | @Validated | ||||||
|  | public class CustomizeExcelController { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private CustomizeExcelService excelService; | ||||||
|  |  | ||||||
|  |     @GetMapping("/orderExcel") | ||||||
|  |     @Operation(summary = "导出订单详情") | ||||||
|  |     @OperateLog(type = EXPORT) | ||||||
|  |     public void exportBusinessExcel(String startTime,String endTime, | ||||||
|  |               HttpServletResponse response) throws IOException { | ||||||
|  |  | ||||||
|  |         List<OrderExcelVO> orderExcelVOS = excelService.exportOrderExcel(startTime, endTime); | ||||||
|  |         // 导出 Excel | ||||||
|  |         ExcelUtils.write(response, "订单详情统计.xls", "数据", OrderExcelVO.class, | ||||||
|  |                 orderExcelVOS); | ||||||
|  |  | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,38 @@ | |||||||
|  | package cn.iocoder.yudao.module.member.controller.admin.customizeExcel.vo; | ||||||
|  |  | ||||||
|  | import com.alibaba.excel.annotation.ExcelProperty; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
|  | @Data | ||||||
|  | public class OrderExcelVO { | ||||||
|  |  | ||||||
|  |     @ExcelProperty("日期") | ||||||
|  |     private String dayTime; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("用户名") | ||||||
|  |     private String nickname; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("手机") | ||||||
|  |     private String mobile; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("时间段") | ||||||
|  |     private String timeSlot; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("总价") | ||||||
|  |     private BigDecimal totalMoney; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("菜名") | ||||||
|  |     private String dishesName; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("单价(元/50g)") | ||||||
|  |     private BigDecimal unitPrice; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("重量(g)") | ||||||
|  |     private String weight; | ||||||
|  |  | ||||||
|  |     @ExcelProperty("价格(元)") | ||||||
|  |     private BigDecimal price; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -128,7 +128,7 @@ public class OrderController { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @GetMapping("/reduction") |     @GetMapping("/reduction") | ||||||
|     @Operation(summary = "根据会员编号,获得会员余额,充值金额,消费金额") |     @Operation(summary = "减免") | ||||||
|     public CommonResult<Boolean> reduction(Long orderId, BigDecimal money){ |     public CommonResult<Boolean> reduction(Long orderId, BigDecimal money){ | ||||||
|         orderService.reduction(orderId,money); |         orderService.reduction(orderId,money); | ||||||
|         return CommonResult.success(true); |         return CommonResult.success(true); | ||||||
|  | |||||||
| @ -6,6 +6,8 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult; | |||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | ||||||
| import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; | import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.order.vo.OrderDetailsReqVO; | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.order.vo.OrderDetailsRespVO; | ||||||
| import cn.iocoder.yudao.module.member.controller.app.order.vo.AppOrderPageReqVO; | import cn.iocoder.yudao.module.member.controller.app.order.vo.AppOrderPageReqVO; | ||||||
| import cn.iocoder.yudao.module.member.controller.app.order.vo.AppOrderRespVO; | import cn.iocoder.yudao.module.member.controller.app.order.vo.AppOrderRespVO; | ||||||
| import cn.iocoder.yudao.module.member.controller.app.order.vo.AppOrderSaveReqVO; | import cn.iocoder.yudao.module.member.controller.app.order.vo.AppOrderSaveReqVO; | ||||||
| @ -30,6 +32,7 @@ import javax.annotation.Resource; | |||||||
| import javax.servlet.http.HttpServletResponse; | import javax.servlet.http.HttpServletResponse; | ||||||
| import javax.validation.Valid; | import javax.validation.Valid; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
|  | import java.math.BigDecimal; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| @ -72,12 +75,7 @@ public class AppOrderController { | |||||||
|         return success(orderService.getOrder(id)); |         return success(orderService.getOrder(id)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     //@GetMapping("/page") |  | ||||||
|     //@Operation(summary = "获得会员订单分页") |  | ||||||
|     //public CommonResult<PageResult<AppOrderRespVO>> getOrderPage(@Valid AppOrderPageReqVO pageReqVO) { |  | ||||||
|     //    PageResult<DishOrderDO> pageResult = orderService.getOrderPage(pageReqVO); |  | ||||||
|     //    return success(BeanUtils.toBean(pageResult, AppOrderRespVO.class)); |  | ||||||
|     //} |  | ||||||
|  |  | ||||||
|     @GetMapping("/export-excel") |     @GetMapping("/export-excel") | ||||||
|     @Operation(summary = "导出会员订单 Excel") |     @Operation(summary = "导出会员订单 Excel") | ||||||
| @ -99,5 +97,18 @@ public class AppOrderController { | |||||||
|         return success(orderList); |         return success(orderList); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/page") | ||||||
|  |     @Operation(summary = "获得会员订单分页") | ||||||
|  |     public CommonResult<PageResult<OrderDetailsRespVO>> getPageResult(@Valid OrderDetailsReqVO reqVO){ | ||||||
|  |         return CommonResult.success(orderService.getPageOrderDetails(reqVO)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/reduction") | ||||||
|  |     @Operation(summary = "减免") | ||||||
|  |     public CommonResult<Boolean> reduction(Long orderId, BigDecimal money){ | ||||||
|  |         orderService.reduction(orderId,money); | ||||||
|  |         return CommonResult.success(true); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
| @ -12,4 +12,6 @@ import lombok.Data; | |||||||
| public class AppPageVo  extends PageParam { | public class AppPageVo  extends PageParam { | ||||||
|  |  | ||||||
|     private Long userId; |     private Long userId; | ||||||
|  |  | ||||||
|  |     private String mobile; | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,5 +16,6 @@ public class OtherVO { | |||||||
|     private String dishesImageUrl; |     private String dishesImageUrl; | ||||||
|     private String sn; |     private String sn; | ||||||
|     private BigDecimal price; |     private BigDecimal price; | ||||||
|  |     private BigDecimal unitPrice; | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -6,6 +6,8 @@ import lombok.AllArgsConstructor; | |||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.NoArgsConstructor; | import lombok.NoArgsConstructor; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
|  |  | ||||||
| @Schema(description = "用户 APP - 用户个人信息 Response VO") | @Schema(description = "用户 APP - 用户个人信息 Response VO") | ||||||
| @Data | @Data | ||||||
| @NoArgsConstructor | @NoArgsConstructor | ||||||
| @ -58,4 +60,29 @@ public class AppMemberUserInfoRespVO { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 余额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal money; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 消费类型 | ||||||
|  |      */ | ||||||
|  |     private String type; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 赠送金额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal giftAmount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 现金金额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal cashAmount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 微信充值金额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal wxAmount; | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -66,4 +66,9 @@ public class OrderDetailDO extends BaseDO { | |||||||
|      * 菜品价格 |      * 菜品价格 | ||||||
|      */ |      */ | ||||||
|     private BigDecimal price; |     private BigDecimal price; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 菜品单价 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal unitPrice; | ||||||
| } | } | ||||||
| @ -19,6 +19,7 @@ import lombok.EqualsAndHashCode; | |||||||
| import lombok.NoArgsConstructor; | import lombok.NoArgsConstructor; | ||||||
| import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | ||||||
|  |  | ||||||
|  | import java.math.BigDecimal; | ||||||
| import java.time.LocalDateTime; | import java.time.LocalDateTime; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @ -154,4 +155,30 @@ public class MemberUserDO extends TenantBaseDO { | |||||||
|      */ |      */ | ||||||
|     private Long faceId; |     private Long faceId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 余额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal money; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 消费类型 | ||||||
|  |      */ | ||||||
|  |     private String type; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 赠送金额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal giftAmount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 现金金额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal cashAmount; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 微信充值金额 | ||||||
|  |      */ | ||||||
|  |     private BigDecimal wxAmount; | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package cn.iocoder.yudao.module.member.dal.mysql.customizeExcel; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.customizeExcel.vo.OrderExcelVO; | ||||||
|  | import org.apache.ibatis.annotations.Mapper; | ||||||
|  | import org.apache.ibatis.annotations.Param; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | @Mapper | ||||||
|  | public interface CustomizeExcelMapper { | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     List<OrderExcelVO> selectOrder(@Param("startTime")String startTime, @Param("endTime")String endTime); | ||||||
|  | } | ||||||
| @ -65,6 +65,7 @@ public class MemberAsyncServiceImpl implements MemberAsyncService{ | |||||||
|         orderDetail.setOrderId(otherVO.getOrderId()).setDishesName(otherVO.getDishesName()).setDishUrl(otherVO.getDishesImageUrl()); |         orderDetail.setOrderId(otherVO.getOrderId()).setDishesName(otherVO.getDishesName()).setDishUrl(otherVO.getDishesImageUrl()); | ||||||
|         orderDetail.setSn(otherVO.getSn()); |         orderDetail.setSn(otherVO.getSn()); | ||||||
|         orderDetail.setPrice(otherVO.getPrice()); |         orderDetail.setPrice(otherVO.getPrice()); | ||||||
|  |         orderDetail.setUnitPrice(otherVO.getUnitPrice()); | ||||||
|         orderDetailMapper.insert(orderDetail); |         orderDetailMapper.insert(orderDetail); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -0,0 +1,14 @@ | |||||||
|  | package cn.iocoder.yudao.module.member.service.customizeExcel; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.customizeExcel.vo.OrderExcelVO; | ||||||
|  | import org.apache.ibatis.annotations.Param; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | public interface CustomizeExcelService { | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     List<OrderExcelVO> exportOrderExcel(String startTime,String endTime); | ||||||
|  | } | ||||||
| @ -0,0 +1,23 @@ | |||||||
|  | package cn.iocoder.yudao.module.member.service.customizeExcel; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.module.member.controller.admin.customizeExcel.vo.OrderExcelVO; | ||||||
|  | import cn.iocoder.yudao.module.member.dal.mysql.customizeExcel.CustomizeExcelMapper; | ||||||
|  | import cn.iocoder.yudao.module.member.service.devicewarn.DeviceWarnService; | ||||||
|  | import cn.iocoder.yudao.module.system.api.deviceInfo.DeviceInfoApi; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import javax.annotation.Resource; | ||||||
|  | import java.util.Collections; | ||||||
|  | import java.util.List; | ||||||
|  | @Service | ||||||
|  | public class CustomizeExcelServiceImpl implements CustomizeExcelService { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private CustomizeExcelMapper customizeExcelMapper; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<OrderExcelVO> exportOrderExcel(String startTime, String endTime) { | ||||||
|  |         return customizeExcelMapper.selectOrder(startTime,endTime); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -95,6 +95,8 @@ public interface OrderService { | |||||||
|     List<DishOrderDO> getDishOrderByTime(LocalDateTime startTime ,LocalDateTime endTime ); |     List<DishOrderDO> getDishOrderByTime(LocalDateTime startTime ,LocalDateTime endTime ); | ||||||
|  |  | ||||||
|     PageResult<OrderDetailsRespVO> getPageOrderDetails(OrderDetailsReqVO reqVO); |     PageResult<OrderDetailsRespVO> getPageOrderDetails(OrderDetailsReqVO reqVO); | ||||||
|  |  | ||||||
|  |  | ||||||
|     OrderDetailsRespVO getOrderDetailsAndUser(Long orderId); |     OrderDetailsRespVO getOrderDetailsAndUser(Long orderId); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ import cn.hutool.core.collection.CollectionUtil; | |||||||
| import cn.hutool.core.util.NumberUtil; | import cn.hutool.core.util.NumberUtil; | ||||||
| import cn.hutool.core.util.ObjUtil; | import cn.hutool.core.util.ObjUtil; | ||||||
| import cn.hutool.core.util.ObjectUtil; | import cn.hutool.core.util.ObjectUtil; | ||||||
|  | import cn.hutool.core.util.StrUtil; | ||||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; | import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
| import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; | import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; | ||||||
| @ -153,7 +154,21 @@ public class OrderServiceImpl implements OrderService { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public PageResult<AppOrderRespVO> getOrderList(AppPageVo vo) { |     public PageResult<AppOrderRespVO> getOrderList(AppPageVo vo) { | ||||||
|         PageResult<DishOrderDO> dishOrderDOPageResult = dishOrderMapper.selectPage(vo, Wrappers.<DishOrderDO>lambdaQuery().eq(DishOrderDO::getUserId, vo.getUserId()).orderByDesc(DishOrderDO::getCreateTime)); |         ArrayList<Long> ids = new ArrayList<>(); | ||||||
|  |         if(StrUtil.isNotEmpty(vo.getMobile())){ | ||||||
|  |             List<MemberUserDO> memberUserDOS = memberUserMapper.selectList(Wrappers.<MemberUserDO>lambdaQuery().like(MemberUserDO::getMobile, vo.getMobile())); | ||||||
|  |             if(CollectionUtil.isNotEmpty(memberUserDOS)){ | ||||||
|  |                 List<Long> collect = memberUserDOS.stream().map(MemberUserDO::getId).collect(Collectors.toList()); | ||||||
|  |                 ids.addAll(collect); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if(vo.getUserId()!=null){ | ||||||
|  |             ids.add(vo.getUserId()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         PageResult<DishOrderDO> dishOrderDOPageResult = dishOrderMapper.selectPage(vo, Wrappers.<DishOrderDO>lambdaQuery() | ||||||
|  |                 .in(CollectionUtil.isNotEmpty(ids),DishOrderDO::getUserId, ids) | ||||||
|  |                 .orderByDesc(DishOrderDO::getCreateTime)); | ||||||
|         PageResult<AppOrderRespVO> appOrderRespVOPageResult = BeanUtils.toBean(dishOrderDOPageResult, AppOrderRespVO.class); |         PageResult<AppOrderRespVO> appOrderRespVOPageResult = BeanUtils.toBean(dishOrderDOPageResult, AppOrderRespVO.class); | ||||||
|         List<AppOrderRespVO> list = appOrderRespVOPageResult.getList(); |         List<AppOrderRespVO> list = appOrderRespVOPageResult.getList(); | ||||||
|         for (AppOrderRespVO dishOrderDO : list) { |         for (AppOrderRespVO dishOrderDO : list) { | ||||||
| @ -196,7 +211,7 @@ public class OrderServiceImpl implements OrderService { | |||||||
|             //根据用户属性获取ids |             //根据用户属性获取ids | ||||||
|             List<MemberUserDO> list = memberUserMapper.selectList(new LambdaQueryWrapperX<MemberUserDO>() |             List<MemberUserDO> list = memberUserMapper.selectList(new LambdaQueryWrapperX<MemberUserDO>() | ||||||
|                     .likeIfPresent(MemberUserDO::getNickname, reqVO.getUserName()) |                     .likeIfPresent(MemberUserDO::getNickname, reqVO.getUserName()) | ||||||
|                     .eqIfPresent(MemberUserDO::getMobile, reqVO.getUserAccount()) |                     .likeIfPresent(MemberUserDO::getMobile, reqVO.getUserAccount()) | ||||||
|                     .eqIfPresent(MemberUserDO::getCardId, reqVO.getUserJob()) |                     .eqIfPresent(MemberUserDO::getCardId, reqVO.getUserJob()) | ||||||
|                     .eqIfPresent(MemberUserDO::getId, reqVO.getUserId()) |                     .eqIfPresent(MemberUserDO::getId, reqVO.getUserId()) | ||||||
|                     .inIfPresent(MemberUserDO::getId, groupMapper.getMemberList(reqVO.getGroupId()))); |                     .inIfPresent(MemberUserDO::getId, groupMapper.getMemberList(reqVO.getGroupId()))); | ||||||
|  | |||||||
| @ -91,7 +91,7 @@ public class OrderDetailServiceImpl implements OrderDetailService { | |||||||
|         otherVO.setDishesName(dish.getDishesName()); |         otherVO.setDishesName(dish.getDishesName()); | ||||||
|         otherVO.setDishesImageUrl(dish.getDishesImageUrl()); |         otherVO.setDishesImageUrl(dish.getDishesImageUrl()); | ||||||
|         otherVO.setPrice(bigDecimal1); |         otherVO.setPrice(bigDecimal1); | ||||||
|  |         otherVO.setUnitPrice(dish.getDishesSumPrice()); | ||||||
|         asyncService.createOrderDetail(createReqVO,otherVO); |         asyncService.createOrderDetail(createReqVO,otherVO); | ||||||
|         // 返回写死 |         // 返回写死 | ||||||
|         return 0L; |         return 0L; | ||||||
|  | |||||||
| @ -0,0 +1,34 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  | <mapper namespace="cn.iocoder.yudao.module.member.dal.mysql.customizeExcel.CustomizeExcelMapper"> | ||||||
|  |  | ||||||
|  |     <!-- | ||||||
|  |         一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。 | ||||||
|  |         无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。 | ||||||
|  |         代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。 | ||||||
|  |         文档可见:https://www.iocoder.cn/MyBatis/x-plugins/ | ||||||
|  |      --> | ||||||
|  |     <select id="selectOrder" resultType="cn.iocoder.yudao.module.member.controller.admin.customizeExcel.vo.OrderExcelVO"> | ||||||
|  |         select | ||||||
|  |             DATE_FORMAT(md.create_time, '%Y-%m-%d') as dayTime, | ||||||
|  |             mu.nickname , | ||||||
|  |             mu.mobile , | ||||||
|  |             CASE | ||||||
|  |               WHEN HOUR(mo.create_time) BETWEEN 0 AND 9 THEN '早' | ||||||
|  |               WHEN HOUR(mo.create_time) BETWEEN 10 AND 15 THEN '中' | ||||||
|  |               WHEN HOUR(mo.create_time) BETWEEN 16 AND 23 THEN '晚' | ||||||
|  |               ELSE '未知' | ||||||
|  |             END AS timeSlot, | ||||||
|  |             mo.total_money , | ||||||
|  |             md.dishes_name , | ||||||
|  |             md.unit_price , | ||||||
|  |             md.weight , | ||||||
|  |             md.price | ||||||
|  |         from member_order_detail md | ||||||
|  |          left join member_dish_order mo on md.order_id = mo.id | ||||||
|  |          left join member_user mu on mu.id = mo.user_id | ||||||
|  |         where DATE_FORMAT(md.create_time, '%Y%m%d') between #{startTime} and #{endTime} | ||||||
|  |         order by mo.user_id,order_id | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @ -195,4 +195,5 @@ public interface ErrorCodeConstants { | |||||||
|  |  | ||||||
|     ErrorCode FACE_DEVICE_INFO_EXISTS = new ErrorCode(1_002_040_003, "设备码已存在"); |     ErrorCode FACE_DEVICE_INFO_EXISTS = new ErrorCode(1_002_040_003, "设备码已存在"); | ||||||
|  |  | ||||||
|  |     ErrorCode DISH_IMAGE_NOT_EXISTS = new ErrorCode(1_002_040_004, "本周菜单不存在"); | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,98 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.controller.admin.dishimage; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImagePageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImageRespVO; | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImageSaveReqVO; | ||||||
|  | import cn.iocoder.yudao.module.system.dal.dataobject.dishimage.DishImageDO; | ||||||
|  | import cn.iocoder.yudao.module.system.service.dishimage.DishImageService; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import javax.annotation.Resource; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
|  | import io.swagger.v3.oas.annotations.tags.Tag; | ||||||
|  | import io.swagger.v3.oas.annotations.Parameter; | ||||||
|  | import io.swagger.v3.oas.annotations.Operation; | ||||||
|  |  | ||||||
|  | import javax.validation.constraints.*; | ||||||
|  | import javax.validation.*; | ||||||
|  | import javax.servlet.http.*; | ||||||
|  | import java.util.*; | ||||||
|  | import java.io.IOException; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageParam; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
|  | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
|  | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; | ||||||
|  | import static cn.iocoder.yudao.framework.operatelog.core.enums.OperateTypeEnum.*; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Tag(name = "管理后台 - 本周菜单") | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/t/dish-image") | ||||||
|  | @Validated | ||||||
|  | public class DishImageController { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private DishImageService dishImageService; | ||||||
|  |  | ||||||
|  |     @PostMapping("/create") | ||||||
|  |     @Operation(summary = "创建本周菜单") | ||||||
|  |     @PreAuthorize("@ss.hasPermission('t:dish-image:create')") | ||||||
|  |     public CommonResult<Integer> createDishImage(@Valid @RequestBody DishImageSaveReqVO createReqVO) { | ||||||
|  |         return success(dishImageService.createDishImage(createReqVO)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @PutMapping("/update") | ||||||
|  |     @Operation(summary = "更新本周菜单") | ||||||
|  |     @PreAuthorize("@ss.hasPermission('t:dish-image:update')") | ||||||
|  |     public CommonResult<Boolean> updateDishImage(@Valid @RequestBody DishImageSaveReqVO updateReqVO) { | ||||||
|  |         dishImageService.updateDishImage(updateReqVO); | ||||||
|  |         return success(true); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @DeleteMapping("/delete") | ||||||
|  |     @Operation(summary = "删除本周菜单") | ||||||
|  |     @Parameter(name = "id", description = "编号", required = true) | ||||||
|  |     @PreAuthorize("@ss.hasPermission('t:dish-image:delete')") | ||||||
|  |     public CommonResult<Boolean> deleteDishImage(@RequestParam("id") Integer id) { | ||||||
|  |         dishImageService.deleteDishImage(id); | ||||||
|  |         return success(true); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/get") | ||||||
|  |     @Operation(summary = "获得本周菜单") | ||||||
|  |     @Parameter(name = "id", description = "编号", required = true, example = "1024") | ||||||
|  |     @PreAuthorize("@ss.hasPermission('t:dish-image:query')") | ||||||
|  |     public CommonResult<DishImageRespVO> getDishImage(@RequestParam("id") Integer id) { | ||||||
|  |         DishImageDO dishImage = dishImageService.getDishImage(id); | ||||||
|  |         return success(BeanUtils.toBean(dishImage, DishImageRespVO.class)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/page") | ||||||
|  |     @Operation(summary = "获得本周菜单分页") | ||||||
|  |     @PreAuthorize("@ss.hasPermission('t:dish-image:query')") | ||||||
|  |     public CommonResult<PageResult<DishImageRespVO>> getDishImagePage(@Valid DishImagePageReqVO pageReqVO) { | ||||||
|  |         PageResult<DishImageDO> pageResult = dishImageService.getDishImagePage(pageReqVO); | ||||||
|  |         return success(BeanUtils.toBean(pageResult, DishImageRespVO.class)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/export-excel") | ||||||
|  |     @Operation(summary = "导出本周菜单 Excel") | ||||||
|  |     @PreAuthorize("@ss.hasPermission('t:dish-image:export')") | ||||||
|  |     @OperateLog(type = EXPORT) | ||||||
|  |     public void exportDishImageExcel(@Valid DishImagePageReqVO pageReqVO, | ||||||
|  |               HttpServletResponse response) throws IOException { | ||||||
|  |         pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); | ||||||
|  |         List<DishImageDO> list = dishImageService.getDishImagePage(pageReqVO).getList(); | ||||||
|  |         // 导出 Excel | ||||||
|  |         ExcelUtils.write(response, "本周菜单.xls", "数据", DishImageRespVO.class, | ||||||
|  |                         BeanUtils.toBean(list, DishImageRespVO.class)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,39 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.controller.admin.dishimage.vo; | ||||||
|  |  | ||||||
|  | import lombok.*; | ||||||
|  | import java.util.*; | ||||||
|  | import io.swagger.v3.oas.annotations.media.Schema; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageParam; | ||||||
|  | import org.springframework.format.annotation.DateTimeFormat; | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  |  | ||||||
|  | import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; | ||||||
|  |  | ||||||
|  | @Schema(description = "管理后台 - 本周菜单分页 Request VO") | ||||||
|  | @Data | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @ToString(callSuper = true) | ||||||
|  | public class DishImagePageReqVO extends PageParam { | ||||||
|  |  | ||||||
|  |     @Schema(description = "名字", example = "张三") | ||||||
|  |     private String name; | ||||||
|  |  | ||||||
|  |     @Schema(description = "开始日期") | ||||||
|  |     @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) | ||||||
|  |     private String[] startDate; | ||||||
|  |  | ||||||
|  |     @Schema(description = "结束日期") | ||||||
|  |     @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) | ||||||
|  |     private String[] endDate; | ||||||
|  |  | ||||||
|  |     @Schema(description = "地址", example = "https://www.iocoder.cn") | ||||||
|  |     private String imageUrl; | ||||||
|  |  | ||||||
|  |     @Schema(description = "备注", example = "随便") | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     @Schema(description = "创建时间") | ||||||
|  |     @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) | ||||||
|  |     private LocalDateTime[] createTime; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,44 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.controller.admin.dishimage.vo; | ||||||
|  |  | ||||||
|  | import io.swagger.v3.oas.annotations.media.Schema; | ||||||
|  | import lombok.*; | ||||||
|  | import java.util.*; | ||||||
|  | import java.util.*; | ||||||
|  | import org.springframework.format.annotation.DateTimeFormat; | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import com.alibaba.excel.annotation.*; | ||||||
|  |  | ||||||
|  | @Schema(description = "管理后台 - 本周菜单 Response VO") | ||||||
|  | @Data | ||||||
|  | @ExcelIgnoreUnannotated | ||||||
|  | public class DishImageRespVO { | ||||||
|  |  | ||||||
|  |     @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "17200") | ||||||
|  |     @ExcelProperty("编号") | ||||||
|  |     private Integer id; | ||||||
|  |  | ||||||
|  |     @Schema(description = "名字", example = "张三") | ||||||
|  |     @ExcelProperty("名字") | ||||||
|  |     private String name; | ||||||
|  |  | ||||||
|  |     @Schema(description = "开始日期") | ||||||
|  |     @ExcelProperty("开始日期") | ||||||
|  |     private String startDate; | ||||||
|  |  | ||||||
|  |     @Schema(description = "结束日期") | ||||||
|  |     @ExcelProperty("结束日期") | ||||||
|  |     private String endDate; | ||||||
|  |  | ||||||
|  |     @Schema(description = "地址", example = "https://www.iocoder.cn") | ||||||
|  |     @ExcelProperty("地址") | ||||||
|  |     private String imageUrl; | ||||||
|  |  | ||||||
|  |     @Schema(description = "备注", example = "随便") | ||||||
|  |     @ExcelProperty("备注") | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  |     @Schema(description = "创建时间") | ||||||
|  |     @ExcelProperty("创建时间") | ||||||
|  |     private LocalDateTime createTime; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,30 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.controller.admin.dishimage.vo; | ||||||
|  |  | ||||||
|  | import io.swagger.v3.oas.annotations.media.Schema; | ||||||
|  | import lombok.*; | ||||||
|  | import java.util.*; | ||||||
|  | import javax.validation.constraints.*; | ||||||
|  |  | ||||||
|  | @Schema(description = "管理后台 - 本周菜单新增/修改 Request VO") | ||||||
|  | @Data | ||||||
|  | public class DishImageSaveReqVO { | ||||||
|  |  | ||||||
|  |     @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "17200") | ||||||
|  |     private Integer id; | ||||||
|  |  | ||||||
|  |     @Schema(description = "名字", example = "张三") | ||||||
|  |     private String name; | ||||||
|  |  | ||||||
|  |     @Schema(description = "开始日期") | ||||||
|  |     private String startDate; | ||||||
|  |  | ||||||
|  |     @Schema(description = "结束日期") | ||||||
|  |     private String endDate; | ||||||
|  |  | ||||||
|  |     @Schema(description = "地址", example = "https://www.iocoder.cn") | ||||||
|  |     private String imageUrl; | ||||||
|  |  | ||||||
|  |     @Schema(description = "备注", example = "随便") | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,51 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.dal.dataobject.dishimage; | ||||||
|  |  | ||||||
|  | import lombok.*; | ||||||
|  | import java.util.*; | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import java.time.LocalDateTime; | ||||||
|  | import com.baomidou.mybatisplus.annotation.*; | ||||||
|  | import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 本周菜单 DO | ||||||
|  |  * | ||||||
|  |  * @author 管理员 | ||||||
|  |  */ | ||||||
|  | @TableName("t_dish_image") | ||||||
|  | @KeySequence("t_dish_image_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。 | ||||||
|  | @Data | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
|  | @ToString(callSuper = true) | ||||||
|  | @Builder | ||||||
|  | @NoArgsConstructor | ||||||
|  | @AllArgsConstructor | ||||||
|  | public class DishImageDO extends BaseDO { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 编号 | ||||||
|  |      */ | ||||||
|  |     @TableId | ||||||
|  |     private Integer id; | ||||||
|  |     /** | ||||||
|  |      * 名字 | ||||||
|  |      */ | ||||||
|  |     private String name; | ||||||
|  |     /** | ||||||
|  |      * 开始日期 | ||||||
|  |      */ | ||||||
|  |     private String startDate; | ||||||
|  |     /** | ||||||
|  |      * 结束日期 | ||||||
|  |      */ | ||||||
|  |     private String endDate; | ||||||
|  |     /** | ||||||
|  |      * 地址 | ||||||
|  |      */ | ||||||
|  |     private String imageUrl; | ||||||
|  |     /** | ||||||
|  |      * 备注 | ||||||
|  |      */ | ||||||
|  |     private String remark; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,33 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.dal.mysql.dishimage; | ||||||
|  |  | ||||||
|  | import java.util.*; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||||
|  | import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; | ||||||
|  | import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImagePageReqVO; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.module.system.dal.dataobject.dishimage.DishImageDO; | ||||||
|  | import org.apache.ibatis.annotations.Mapper; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 本周菜单 Mapper | ||||||
|  |  * | ||||||
|  |  * @author 管理员 | ||||||
|  |  */ | ||||||
|  | @Mapper | ||||||
|  | public interface DishImageMapper extends BaseMapperX<DishImageDO> { | ||||||
|  |  | ||||||
|  |     default PageResult<DishImageDO> selectPage(DishImagePageReqVO reqVO) { | ||||||
|  |         return selectPage(reqVO, new LambdaQueryWrapperX<DishImageDO>() | ||||||
|  |                 .likeIfPresent(DishImageDO::getName, reqVO.getName()) | ||||||
|  |                 .betweenIfPresent(DishImageDO::getStartDate, reqVO.getStartDate()) | ||||||
|  |                 .betweenIfPresent(DishImageDO::getEndDate, reqVO.getEndDate()) | ||||||
|  |                 .eqIfPresent(DishImageDO::getImageUrl, reqVO.getImageUrl()) | ||||||
|  |                 .eqIfPresent(DishImageDO::getRemark, reqVO.getRemark()) | ||||||
|  |                 .betweenIfPresent(DishImageDO::getCreateTime, reqVO.getCreateTime()) | ||||||
|  |                 .orderByDesc(DishImageDO::getId)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,57 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.service.dishimage; | ||||||
|  |  | ||||||
|  | import java.util.*; | ||||||
|  | import javax.validation.*; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageParam; | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImagePageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImageSaveReqVO; | ||||||
|  | import cn.iocoder.yudao.module.system.dal.dataobject.dishimage.DishImageDO; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 本周菜单 Service 接口 | ||||||
|  |  * | ||||||
|  |  * @author 管理员 | ||||||
|  |  */ | ||||||
|  | public interface DishImageService { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建本周菜单 | ||||||
|  |      * | ||||||
|  |      * @param createReqVO 创建信息 | ||||||
|  |      * @return 编号 | ||||||
|  |      */ | ||||||
|  |     Integer createDishImage(@Valid DishImageSaveReqVO createReqVO); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 更新本周菜单 | ||||||
|  |      * | ||||||
|  |      * @param updateReqVO 更新信息 | ||||||
|  |      */ | ||||||
|  |     void updateDishImage(@Valid DishImageSaveReqVO updateReqVO); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除本周菜单 | ||||||
|  |      * | ||||||
|  |      * @param id 编号 | ||||||
|  |      */ | ||||||
|  |     void deleteDishImage(Integer id); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获得本周菜单 | ||||||
|  |      * | ||||||
|  |      * @param id 编号 | ||||||
|  |      * @return 本周菜单 | ||||||
|  |      */ | ||||||
|  |     DishImageDO getDishImage(Integer id); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获得本周菜单分页 | ||||||
|  |      * | ||||||
|  |      * @param pageReqVO 分页查询 | ||||||
|  |      * @return 本周菜单分页 | ||||||
|  |      */ | ||||||
|  |     PageResult<DishImageDO> getDishImagePage(DishImagePageReqVO pageReqVO); | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -0,0 +1,78 @@ | |||||||
|  | package cn.iocoder.yudao.module.system.service.dishimage; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImagePageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.system.controller.admin.dishimage.vo.DishImageSaveReqVO; | ||||||
|  | import cn.iocoder.yudao.module.system.dal.dataobject.dishimage.DishImageDO; | ||||||
|  | import cn.iocoder.yudao.module.system.dal.mysql.dishimage.DishImageMapper; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  | import javax.annotation.Resource; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.transaction.annotation.Transactional; | ||||||
|  |  | ||||||
|  | import java.util.*; | ||||||
|  |  | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||||
|  | import cn.iocoder.yudao.framework.common.pojo.PageParam; | ||||||
|  | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception; | ||||||
|  | import static cn.iocoder.yudao.module.system.enums.ErrorCodeConstants.DISH_IMAGE_NOT_EXISTS; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 本周菜单 Service 实现类 | ||||||
|  |  * | ||||||
|  |  * @author 管理员 | ||||||
|  |  */ | ||||||
|  | @Service | ||||||
|  | @Validated | ||||||
|  | public class DishImageServiceImpl implements DishImageService { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private DishImageMapper dishImageMapper; | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public Integer createDishImage(DishImageSaveReqVO createReqVO) { | ||||||
|  |         // 插入 | ||||||
|  |         DishImageDO dishImage = BeanUtils.toBean(createReqVO, DishImageDO.class); | ||||||
|  |         dishImageMapper.insert(dishImage); | ||||||
|  |         // 返回 | ||||||
|  |         return dishImage.getId(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void updateDishImage(DishImageSaveReqVO updateReqVO) { | ||||||
|  |         // 校验存在 | ||||||
|  |         validateDishImageExists(updateReqVO.getId()); | ||||||
|  |         // 更新 | ||||||
|  |         DishImageDO updateObj = BeanUtils.toBean(updateReqVO, DishImageDO.class); | ||||||
|  |         dishImageMapper.updateById(updateObj); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void deleteDishImage(Integer id) { | ||||||
|  |         // 校验存在 | ||||||
|  |         validateDishImageExists(id); | ||||||
|  |         // 删除 | ||||||
|  |         dishImageMapper.deleteById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void validateDishImageExists(Integer id) { | ||||||
|  |         if (dishImageMapper.selectById(id) == null) { | ||||||
|  |             throw exception(DISH_IMAGE_NOT_EXISTS); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public DishImageDO getDishImage(Integer id) { | ||||||
|  |         return dishImageMapper.selectById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public PageResult<DishImageDO> getDishImagePage(DishImagePageReqVO pageReqVO) { | ||||||
|  |         return dishImageMapper.selectPage(pageReqVO); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -8,7 +8,7 @@ spring: | |||||||
|   autoconfigure: |   autoconfigure: | ||||||
|     exclude: |     exclude: | ||||||
|       - com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 排除 Druid 的自动配置,使用 dynamic-datasource-spring-boot-starter 配置多数据源 |       - com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 排除 Druid 的自动配置,使用 dynamic-datasource-spring-boot-starter 配置多数据源 | ||||||
| #      - org.springframework.boot.autoconfigure.quartz.QuartzAutoConfiguration # 默认 local 环境,不开启 Quartz 的自动配置 |       - org.springframework.boot.autoconfigure.quartz.QuartzAutoConfiguration # 默认 local 环境,不开启 Quartz 的自动配置 | ||||||
|       - de.codecentric.boot.admin.server.config.AdminServerAutoConfiguration # 禁用 Spring Boot Admin 的 Server 的自动配置 |       - de.codecentric.boot.admin.server.config.AdminServerAutoConfiguration # 禁用 Spring Boot Admin 的 Server 的自动配置 | ||||||
|       - de.codecentric.boot.admin.server.ui.config.AdminServerUiAutoConfiguration # 禁用 Spring Boot Admin 的 Server UI 的自动配置 |       - de.codecentric.boot.admin.server.ui.config.AdminServerUiAutoConfiguration # 禁用 Spring Boot Admin 的 Server UI 的自动配置 | ||||||
|       - de.codecentric.boot.admin.client.config.SpringBootAdminClientAutoConfiguration # 禁用 Spring Boot Admin 的 Client 的自动配置 |       - de.codecentric.boot.admin.client.config.SpringBootAdminClientAutoConfiguration # 禁用 Spring Boot Admin 的 Client 的自动配置 | ||||||
| @ -49,7 +49,7 @@ spring: | |||||||
|         master: |         master: | ||||||
| #          name: yudao | #          name: yudao | ||||||
| #          url: jdbc:mysql://124.223.90.54:6975/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&serverTimezone=CTT&allowPublicKeyRetrieval=true | #          url: jdbc:mysql://124.223.90.54:6975/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&serverTimezone=CTT&allowPublicKeyRetrieval=true | ||||||
|           url: jdbc:mysql://124.223.90.54:6975/yudao?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&nullCatalogMeansCurrent=true |           url: jdbc:mysql://localhost:33006/yudao?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&nullCatalogMeansCurrent=true | ||||||
|  |  | ||||||
| #          url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 | #          url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&nullCatalogMeansCurrent=true # MySQL Connector/J 8.X 连接的示例 | ||||||
|           #          url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 |           #          url: jdbc:mysql://127.0.0.1:3306/${spring.datasource.dynamic.datasource.master.name}?useSSL=false&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=CTT # MySQL Connector/J 5.X 连接的示例 | ||||||
| @ -58,7 +58,7 @@ spring: | |||||||
|           #          url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.master.name} # SQLServer 连接的示例 |           #          url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=${spring.datasource.dynamic.datasource.master.name} # SQLServer 连接的示例 | ||||||
|           #          url: jdbc:dm://10.211.55.4:5236?schema=RUOYI_VUE_PRO # DM 连接的示例 |           #          url: jdbc:dm://10.211.55.4:5236?schema=RUOYI_VUE_PRO # DM 连接的示例 | ||||||
|           username: root |           username: root | ||||||
|           password: Emjlmlwj1! |           password: JXLZZX79 | ||||||
|         #          username: sa |         #          username: sa | ||||||
|         #          password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W |         #          password: JSm:g(*%lU4ZAkz06cd52KqT3)i1?H7W | ||||||
|         #          username: SYSDBA # DM 连接的示例 |         #          username: SYSDBA # DM 连接的示例 | ||||||
| @ -78,11 +78,11 @@ spring: | |||||||
|  |  | ||||||
|   # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优 |   # Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优 | ||||||
|   redis: |   redis: | ||||||
|     host: 220.200.155.28 # 地址 |     host: localhost # 地址 | ||||||
|     port: 21103 # 端口 |     port: 63079 # 端口 | ||||||
|     database: 2 # 数据库索引 |     database: 1 # 数据库索引 | ||||||
|     # 密码 |     # 密码 | ||||||
|     password: auistdguasyghtdas |     password: JXLZZX79 | ||||||
|     # 连接超时时间 |     # 连接超时时间 | ||||||
|     timeout: 10s |     timeout: 10s | ||||||
| #    password: dev # 密码,建议生产环境开启 | #    password: dev # 密码,建议生产环境开启 | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 seesaw
					seesaw