更新了写真预约模块
This commit is contained in:
parent
2b271e7882
commit
4d9ecd757f
|
@ -22,4 +22,7 @@ public class MyBatisPlusConfig {
|
||||||
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
|
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
|
||||||
return interceptor;
|
return interceptor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -36,6 +36,7 @@ import org.springframework.web.bind.annotation.RequestBody;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
|
@ -101,10 +102,10 @@ public class PhotoCategoryController {
|
||||||
if (photoCategoryUpdateRequest == null || photoCategoryUpdateRequest.getId() <= 0) {
|
if (photoCategoryUpdateRequest == null || photoCategoryUpdateRequest.getId() <= 0) {
|
||||||
throw new BusinessException(ErrorCode.PARAMS_ERROR);
|
throw new BusinessException(ErrorCode.PARAMS_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取原有写真类别名称
|
// 获取原有写真类别名称
|
||||||
Long id = photoCategoryUpdateRequest.getId();
|
Long id = photoCategoryUpdateRequest.getId();
|
||||||
PhotoCategory originPhotoCategory = photoCategoryService.getById(id);
|
PhotoCategory originPhotoCategory = photoCategoryService.getById(id);
|
||||||
|
ThrowUtils.throwIf(originPhotoCategory == null, ErrorCode.OPERATION_ERROR, "写真类别不存在");
|
||||||
String originName = originPhotoCategory.getName();
|
String originName = originPhotoCategory.getName();
|
||||||
// 获取目标写真预约名称
|
// 获取目标写真预约名称
|
||||||
String targetName = photoCategoryUpdateRequest.getName();
|
String targetName = photoCategoryUpdateRequest.getName();
|
||||||
|
@ -112,8 +113,7 @@ public class PhotoCategoryController {
|
||||||
// 更新原有写真类别下所有的写真产品类名
|
// 更新原有写真类别下所有的写真产品类名
|
||||||
UpdateWrapper<PhotoProducts> updateWrapper = new UpdateWrapper<>();
|
UpdateWrapper<PhotoProducts> updateWrapper = new UpdateWrapper<>();
|
||||||
updateWrapper.eq("categoryName", originName).set("categoryName", targetName);
|
updateWrapper.eq("categoryName", originName).set("categoryName", targetName);
|
||||||
boolean update = photoProductsService.update(updateWrapper);
|
photoProductsService.update(updateWrapper);
|
||||||
ThrowUtils.throwIf(!update, ErrorCode.OPERATION_ERROR, "写真产品类名更新失败");
|
|
||||||
// 更新写真类别名称
|
// 更新写真类别名称
|
||||||
PhotoCategory photoCategory = new PhotoCategory();
|
PhotoCategory photoCategory = new PhotoCategory();
|
||||||
BeanUtils.copyProperties(photoCategoryUpdateRequest, photoCategory);
|
BeanUtils.copyProperties(photoCategoryUpdateRequest, photoCategory);
|
||||||
|
@ -141,16 +141,23 @@ public class PhotoCategoryController {
|
||||||
}
|
}
|
||||||
Long id = commonRequest.getId();
|
Long id = commonRequest.getId();
|
||||||
PhotoCategory photoCategory = photoCategoryService.getById(id);
|
PhotoCategory photoCategory = photoCategoryService.getById(id);
|
||||||
|
ThrowUtils.throwIf(photoCategory == null, ErrorCode.OPERATION_ERROR, "写真类别不存在");
|
||||||
QueryWrapper<PhotoProducts> queryWrapper = new QueryWrapper<>();
|
QueryWrapper<PhotoProducts> queryWrapper = new QueryWrapper<>();
|
||||||
queryWrapper.eq("categoryName", photoCategory.getName());
|
queryWrapper.eq("categoryName", photoCategory.getName());
|
||||||
List<PhotoProducts> photoProductsList = photoProductsService.list(queryWrapper);
|
List<PhotoProducts> photoProductsList = photoProductsService.list(queryWrapper);
|
||||||
// 获取预约日期列表
|
// 获取预约日期表
|
||||||
List<BookingDate> bookingDateList = commonService.getItemsByIds(photoProductsList, bookingDateService, PhotoProducts::getId);
|
List<Long> photoProductIds = photoProductsList.stream().map(PhotoProducts::getId).toList();
|
||||||
// 获取预约时间列表
|
QueryWrapper<BookingDate> bookingDateQueryWrapper = new QueryWrapper<>();
|
||||||
List<BookingTime> bookingTimes = commonService.getItemsByIds(bookingDateList, bookingTimeService, BookingDate::getId);
|
bookingDateQueryWrapper.in("photoProductId", photoProductIds);
|
||||||
|
List<BookingDate> bookingDateList = bookingDateService.list(bookingDateQueryWrapper);
|
||||||
|
// 获取预约时间表
|
||||||
|
List<Long> bookingDateIds = bookingDateList.stream().map(BookingDate::getId).toList();
|
||||||
|
QueryWrapper<BookingTime> bookingTimeQueryWrapper = new QueryWrapper<>();
|
||||||
|
bookingTimeQueryWrapper.in("bookingDateId", bookingDateIds);
|
||||||
|
List<BookingTime> bookingTimeList = bookingTimeService.list(bookingTimeQueryWrapper);
|
||||||
|
|
||||||
// 批量删除预约时间
|
// 批量删除预约时间
|
||||||
boolean removeTime = bookingTimeService.removeBatchByIds(bookingTimes);
|
boolean removeTime = bookingTimeService.removeBatchByIds(bookingTimeList);
|
||||||
ThrowUtils.throwIf(!removeTime, ErrorCode.OPERATION_ERROR, "预约时间删除失败");
|
ThrowUtils.throwIf(!removeTime, ErrorCode.OPERATION_ERROR, "预约时间删除失败");
|
||||||
|
|
||||||
// 批量删除预约日期
|
// 批量删除预约日期
|
||||||
|
@ -203,9 +210,11 @@ public class PhotoCategoryController {
|
||||||
List<String> typeNameList = photoProductsList.stream().map(PhotoProducts::getCategoryName).toList();
|
List<String> typeNameList = photoProductsList.stream().map(PhotoProducts::getCategoryName).toList();
|
||||||
|
|
||||||
QueryWrapper<PhotoCategory> categoryWrapper = new QueryWrapper<>();
|
QueryWrapper<PhotoCategory> categoryWrapper = new QueryWrapper<>();
|
||||||
categoryWrapper.in("name", typeNameList);
|
List<PhotoCategory> categoryList = new ArrayList<>();
|
||||||
List<PhotoCategory> categoryList = photoCategoryService.list(categoryWrapper);
|
if (!typeNameList.isEmpty()) {
|
||||||
|
categoryWrapper.in("name", typeNameList);
|
||||||
|
categoryList = photoCategoryService.list(categoryWrapper);
|
||||||
|
}
|
||||||
List<PhotoCategoryVO> photoCategoryVOS = categoryList.stream().map(photoCategory -> {
|
List<PhotoCategoryVO> photoCategoryVOS = categoryList.stream().map(photoCategory -> {
|
||||||
PhotoCategoryVO photoCategoryVO = new PhotoCategoryVO();
|
PhotoCategoryVO photoCategoryVO = new PhotoCategoryVO();
|
||||||
BeanUtils.copyProperties(photoCategory, photoCategoryVO);
|
BeanUtils.copyProperties(photoCategory, photoCategoryVO);
|
||||||
|
|
|
@ -246,22 +246,26 @@ public class PhotoProductsController {
|
||||||
// 获取写真产品列表
|
// 获取写真产品列表
|
||||||
List<PhotoProducts> records = page.getRecords();
|
List<PhotoProducts> records = page.getRecords();
|
||||||
// 获取预约日期表
|
// 获取预约日期表
|
||||||
List<BookingDate> bookingDateList = commonService.getItemsByIds(records, bookingDateService, PhotoProducts::getId);
|
List<Long> photoProductIds = records.stream().map(PhotoProducts::getId).toList();
|
||||||
|
QueryWrapper<BookingDate> bookingDateQueryWrapper = new QueryWrapper<>();
|
||||||
|
bookingDateQueryWrapper.in("photoProductId", photoProductIds);
|
||||||
|
List<BookingDate> bookingDateList = bookingDateService.list(bookingDateQueryWrapper);
|
||||||
// 获取预约时间表
|
// 获取预约时间表
|
||||||
List<BookingTime> bookingTimeList = commonService.getItemsByIds(bookingDateList, bookingTimeService, BookingDate::getId);
|
List<Long> bookingDateIds = bookingDateList.stream().map(BookingDate::getId).toList();
|
||||||
// 封装成BookingTimeVO列表
|
QueryWrapper<BookingTime> bookingTimeQueryWrapper = new QueryWrapper<>();
|
||||||
|
bookingTimeQueryWrapper.in("bookingDateId", bookingDateIds);
|
||||||
|
List<BookingTime> bookingTimeList = bookingTimeService.list(bookingTimeQueryWrapper);
|
||||||
|
// 封装成BookingTimeVO列表, 并将预约时间从小到大排序
|
||||||
List<BookingTimeVO> bookingTimeVOList = bookingTimeList.stream().map(bookingTime -> {
|
List<BookingTimeVO> bookingTimeVOList = bookingTimeList.stream().map(bookingTime -> {
|
||||||
BookingTimeVO bookingTimeVO = new BookingTimeVO();
|
BookingTimeVO bookingTimeVO = new BookingTimeVO();
|
||||||
BeanUtils.copyProperties(bookingTime, bookingTimeVO);
|
BeanUtils.copyProperties(bookingTime, bookingTimeVO);
|
||||||
return bookingTimeVO;
|
return bookingTimeVO;
|
||||||
}).toList();
|
}).sorted((b1, b2) -> {
|
||||||
|
|
||||||
// 将预约时间从小到大排序
|
|
||||||
bookingTimeVOList.sort((b1, b2) -> {
|
|
||||||
DateTime time1 = DateUtil.parse(b1.getTimePoint(), "HH:mm");
|
DateTime time1 = DateUtil.parse(b1.getTimePoint(), "HH:mm");
|
||||||
DateTime time2 = DateUtil.parse(b2.getTimePoint(), "HH:mm");
|
DateTime time2 = DateUtil.parse(b2.getTimePoint(), "HH:mm");
|
||||||
return time1.compareTo(time2); // 按照时间升序排序
|
return time1.compareTo(time2); // 按照时间升序排序
|
||||||
});
|
}).toList();
|
||||||
|
|
||||||
|
|
||||||
// 封装成BookingDateVO列表
|
// 封装成BookingDateVO列表
|
||||||
List<BookingDateVO> bookingDateVOS = new ArrayList<>();
|
List<BookingDateVO> bookingDateVOS = new ArrayList<>();
|
||||||
|
@ -320,6 +324,8 @@ public class PhotoProductsController {
|
||||||
}
|
}
|
||||||
Long id = commonRequest.getId();
|
Long id = commonRequest.getId();
|
||||||
PhotoProducts photoProducts = photoProductsService.getById(id);
|
PhotoProducts photoProducts = photoProductsService.getById(id);
|
||||||
|
System.out.println("\n\n\n\n\n");
|
||||||
|
System.out.println(photoProducts);
|
||||||
ThrowUtils.throwIf(photoProducts == null || photoProducts.getIsShelves() == 0, ErrorCode.OPERATION_ERROR, "该商品已被删除或者已下架");
|
ThrowUtils.throwIf(photoProducts == null || photoProducts.getIsShelves() == 0, ErrorCode.OPERATION_ERROR, "该商品已被删除或者已下架");
|
||||||
|
|
||||||
// 获取预约日期表
|
// 获取预约日期表
|
||||||
|
@ -327,20 +333,20 @@ public class PhotoProductsController {
|
||||||
queryWrapper.eq("photoProductId", id);
|
queryWrapper.eq("photoProductId", id);
|
||||||
List<BookingDate> bookingDateList = bookingDateService.list(queryWrapper);
|
List<BookingDate> bookingDateList = bookingDateService.list(queryWrapper);
|
||||||
// 获取预约时间表
|
// 获取预约时间表
|
||||||
List<BookingTime> bookingTimeList = commonService.getItemsByIds(bookingDateList, bookingTimeService, BookingDate::getId);
|
List<Long> bookingDateIds = bookingDateList.stream().map(BookingDate::getId).toList();
|
||||||
// 封装成BookingTimeVO列表
|
QueryWrapper<BookingTime> bookingTimeQueryWrapper = new QueryWrapper<>();
|
||||||
|
bookingTimeQueryWrapper.in("bookingDateId", bookingDateIds);
|
||||||
|
List<BookingTime> bookingTimeList = bookingTimeService.list(bookingTimeQueryWrapper);
|
||||||
|
// 封装成BookingTimeVO列表, 并将预约时间从小到大排序
|
||||||
List<BookingTimeVO> bookingTimeVOList = bookingTimeList.stream().map(bookingTime -> {
|
List<BookingTimeVO> bookingTimeVOList = bookingTimeList.stream().map(bookingTime -> {
|
||||||
BookingTimeVO bookingTimeVO = new BookingTimeVO();
|
BookingTimeVO bookingTimeVO = new BookingTimeVO();
|
||||||
BeanUtils.copyProperties(bookingTime, bookingTimeVO);
|
BeanUtils.copyProperties(bookingTime, bookingTimeVO);
|
||||||
return bookingTimeVO;
|
return bookingTimeVO;
|
||||||
}).toList();
|
}).sorted((b1, b2) -> {
|
||||||
|
|
||||||
// 将预约时间从小到大排序
|
|
||||||
bookingTimeVOList.sort((b1, b2) -> {
|
|
||||||
DateTime time1 = DateUtil.parse(b1.getTimePoint(), "HH:mm");
|
DateTime time1 = DateUtil.parse(b1.getTimePoint(), "HH:mm");
|
||||||
DateTime time2 = DateUtil.parse(b2.getTimePoint(), "HH:mm");
|
DateTime time2 = DateUtil.parse(b2.getTimePoint(), "HH:mm");
|
||||||
return time1.compareTo(time2); // 按照时间升序排序
|
return time1.compareTo(time2); // 按照时间升序排序
|
||||||
});
|
}).toList();
|
||||||
|
|
||||||
// 封装成BookingDateVO列表
|
// 封装成BookingDateVO列表
|
||||||
List<BookingDateVO> bookingDateVOS = new ArrayList<>();
|
List<BookingDateVO> bookingDateVOS = new ArrayList<>();
|
||||||
|
@ -389,7 +395,7 @@ public class PhotoProductsController {
|
||||||
|
|
||||||
// 封装成BookingPhotoProductsVO列表
|
// 封装成BookingPhotoProductsVO列表
|
||||||
PhotoProductsVO photoProductsVO = new PhotoProductsVO();
|
PhotoProductsVO photoProductsVO = new PhotoProductsVO();
|
||||||
BeanUtils.copyProperties(photoProductsVO, photoProductsVO);
|
BeanUtils.copyProperties(photoProducts, photoProductsVO);
|
||||||
photoProductsVO.setBookingDateVOList(bookingDateVOList);
|
photoProductsVO.setBookingDateVOList(bookingDateVOList);
|
||||||
|
|
||||||
return ResultUtils.success(photoProductsVO);
|
return ResultUtils.success(photoProductsVO);
|
||||||
|
@ -414,6 +420,7 @@ public class PhotoProductsController {
|
||||||
// 获取当前服务类商品的上(下)架状态
|
// 获取当前服务类商品的上(下)架状态
|
||||||
Long id = commonRequest.getId();
|
Long id = commonRequest.getId();
|
||||||
PhotoProducts photoProducts = photoProductsService.getById(id);
|
PhotoProducts photoProducts = photoProductsService.getById(id);
|
||||||
|
ThrowUtils.throwIf(photoProducts == null, ErrorCode.OPERATION_ERROR, "写真产品不存在");
|
||||||
Integer status = photoProducts.getIsShelves() == 0 ? 1 : 0;
|
Integer status = photoProducts.getIsShelves() == 0 ? 1 : 0;
|
||||||
UpdateWrapper<PhotoProducts> updateWrapper = new UpdateWrapper<>();
|
UpdateWrapper<PhotoProducts> updateWrapper = new UpdateWrapper<>();
|
||||||
updateWrapper.eq("id", id);
|
updateWrapper.eq("id", id);
|
||||||
|
|
|
@ -167,6 +167,7 @@ public class CategoryController {
|
||||||
// 获取原有的类别名称
|
// 获取原有的类别名称
|
||||||
Long id = categoryUpdateRequest.getId();
|
Long id = categoryUpdateRequest.getId();
|
||||||
Category originCategory = categoryService.getById(id);
|
Category originCategory = categoryService.getById(id);
|
||||||
|
ThrowUtils.throwIf(originCategory == null, ErrorCode.OPERATION_ERROR, "类别不存在");
|
||||||
String originTypeName = originCategory.getTypeName();
|
String originTypeName = originCategory.getTypeName();
|
||||||
// 获取目标的类别名称
|
// 获取目标的类别名称
|
||||||
String targetTypeName = categoryUpdateRequest.getTypeName();
|
String targetTypeName = categoryUpdateRequest.getTypeName();
|
||||||
|
|
|
@ -0,0 +1,34 @@
|
||||||
|
package com.cultural.heritage.handler;
|
||||||
|
|
||||||
|
import org.apache.ibatis.type.BaseTypeHandler;
|
||||||
|
import org.apache.ibatis.type.JdbcType;
|
||||||
|
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
|
||||||
|
public class StringArrayTypeHandler extends BaseTypeHandler<String[]> {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setNonNullParameter(PreparedStatement ps, int i, String[] parameter, JdbcType jdbcType) throws SQLException {
|
||||||
|
ps.setString(i, String.join(",", parameter)); // 将字符串数组拼接为一个逗号分隔的字符串
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String[] getNullableResult(ResultSet rs, String columnName) throws SQLException {
|
||||||
|
String result = rs.getString(columnName);
|
||||||
|
return result != null ? result.split(",") : null; // 反向解析为字符串数组
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String[] getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
|
||||||
|
String result = rs.getString(columnIndex);
|
||||||
|
return result != null ? result.split(",") : null; // 反向解析为字符串数组
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String[] getNullableResult(java.sql.CallableStatement cs, int columnIndex) throws SQLException {
|
||||||
|
String result = cs.getString(columnIndex);
|
||||||
|
return result != null ? result.split(",") : null; // 反向解析为字符串数组
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,8 +1,10 @@
|
||||||
package com.cultural.heritage.model.entity;
|
package com.cultural.heritage.model.entity;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.IdType;
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import com.cultural.heritage.handler.StringArrayTypeHandler;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
import java.io.Serial;
|
import java.io.Serial;
|
||||||
|
@ -17,7 +19,7 @@ import java.util.Date;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@TableName("photo_products")
|
@TableName("photo_products")
|
||||||
public class PhotoProducts extends Good implements Serializable {
|
public class PhotoProducts implements Serializable {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -42,6 +44,7 @@ public class PhotoProducts extends Good implements Serializable {
|
||||||
/**
|
/**
|
||||||
* 效果图
|
* 效果图
|
||||||
*/
|
*/
|
||||||
|
@TableField(typeHandler = StringArrayTypeHandler.class)
|
||||||
private String [] effectImg;
|
private String [] effectImg;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -19,4 +19,17 @@ public interface CommonService {
|
||||||
* 根据 ID 列表获取对应的实体列表
|
* 根据 ID 列表获取对应的实体列表
|
||||||
*/
|
*/
|
||||||
<T> List<T> getListByIds(List<Long> ids, IService<T> genericService);
|
<T> List<T> getListByIds(List<Long> ids, IService<T> genericService);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从第一个集合中提取某个属性值,并用这些值作为查询条件去查询第二个集合的数据。
|
||||||
|
* @param sourceList 原始集合(源数据)
|
||||||
|
* @param service 要执行查询的 Service
|
||||||
|
* @param sourceField 在原始集合中提取的字段名
|
||||||
|
* @param targetField 在目标集合中的查询字段名
|
||||||
|
* @param <T> 目标查询实体类型
|
||||||
|
* @return 查询结果集合
|
||||||
|
*/
|
||||||
|
<T> List<T> findListByField(List<?> sourceList, IService<T> service, String sourceField, String targetField);
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@ import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
import com.cultural.heritage.service.common.CommonService;
|
import com.cultural.heritage.service.common.CommonService;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
@ -44,4 +45,52 @@ public class CommonServiceImpl implements CommonService {
|
||||||
// 调用具体的服务执行查询
|
// 调用具体的服务执行查询
|
||||||
return genericService.list(queryWrapper);
|
return genericService.list(queryWrapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 从第一个集合中提取某个属性值,并用这些值作为查询条件去查询第二个集合的数据。
|
||||||
|
* @param sourceList 原始集合(源数据)
|
||||||
|
* @param service 要执行查询的 Service
|
||||||
|
* @param sourceField 在原始集合中提取的字段名
|
||||||
|
* @param targetField 在目标集合中的查询字段名
|
||||||
|
* @param <T> 目标查询实体类型
|
||||||
|
* @return 查询结果集合
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public <T> List<T> findListByField(List<?> sourceList, IService<T> service, String sourceField, String targetField) {
|
||||||
|
// 使用反射获取源集合中对应字段的值
|
||||||
|
List<Object> fieldValues = sourceList.stream()
|
||||||
|
.map(item -> getFieldValue(item, sourceField)) // 获取字段值
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
|
// 如果 fieldValues 为空,直接返回空集合
|
||||||
|
if (fieldValues.isEmpty()) {
|
||||||
|
return List.of(); // 返回空集合
|
||||||
|
}
|
||||||
|
// 创建查询条件
|
||||||
|
QueryWrapper<T> queryWrapper = new QueryWrapper<>();
|
||||||
|
queryWrapper.in(targetField, fieldValues); // 根据字段值进行查询
|
||||||
|
|
||||||
|
return service.list(queryWrapper); // 执行查询并返回结果
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 使用反射获取对象的字段值
|
||||||
|
* @param object 对象
|
||||||
|
* @param fieldName 字段名
|
||||||
|
* @return 字段的值
|
||||||
|
*/
|
||||||
|
private Object getFieldValue(Object object, String fieldName) {
|
||||||
|
try {
|
||||||
|
Field field = object.getClass().getDeclaredField(fieldName);
|
||||||
|
field.setAccessible(true);
|
||||||
|
return field.get(object);
|
||||||
|
} catch (NoSuchFieldException | IllegalAccessException e) {
|
||||||
|
throw new RuntimeException("字段获取失败", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,8 +21,6 @@ spring:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# 测试环境
|
# 测试环境
|
||||||
# driver-class-name: com.mysql.cj.jdbc.Driver
|
# driver-class-name: com.mysql.cj.jdbc.Driver
|
||||||
# url: jdbc:mysql://123.249.108.160:3306/feiyi?serverTimezone=Asia/Shanghai
|
# url: jdbc:mysql://123.249.108.160:3306/feiyi?serverTimezone=Asia/Shanghai
|
||||||
|
@ -54,7 +52,6 @@ server:
|
||||||
cookie:
|
cookie:
|
||||||
max-age: 2592000
|
max-age: 2592000
|
||||||
|
|
||||||
|
|
||||||
mybatis-plus:
|
mybatis-plus:
|
||||||
mapper-locations: classpath:mapper/*.xml
|
mapper-locations: classpath:mapper/*.xml
|
||||||
configuration:
|
configuration:
|
||||||
|
@ -65,6 +62,7 @@ mybatis-plus:
|
||||||
logic-delete-field: isDelete #全局逻辑删除的实体字段名
|
logic-delete-field: isDelete #全局逻辑删除的实体字段名
|
||||||
logic-delete-value: 1 #逻辑已删除值(默认为1)
|
logic-delete-value: 1 #逻辑已删除值(默认为1)
|
||||||
logic-not-delete-value: 0 #逻辑未删除值(默认为0)
|
logic-not-delete-value: 0 #逻辑未删除值(默认为0)
|
||||||
|
type-handlers-package: com.cultural.heritage.handler
|
||||||
|
|
||||||
|
|
||||||
hwyun:
|
hwyun:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user