Merge remote-tracking branch 'origin/test' into test

This commit is contained in:
2025-12-23 15:34:11 +08:00
2 changed files with 55 additions and 4 deletions

View File

@@ -1,7 +1,15 @@
package com.czg.config;
import com.mybatisflex.core.audit.AuditManager;
import com.mybatisflex.core.paginate.Page;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.jetbrains.annotations.NotNull;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.config.BeanPostProcessor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
@@ -21,4 +29,50 @@ public class MybatisFlexConfig {
);
}
/**
* 处理 Spring 容器管理的 Page Bean
*/
@Bean
public BeanPostProcessor pageBeanPostProcessor() {
return new BeanPostProcessor() {
@Override
public Object postProcessAfterInitialization(@NotNull Object bean, @NotNull String beanName) throws BeansException {
if (bean instanceof Page<?> page) {
resetPageDefaultValue(page);
}
return bean;
}
};
}
/**
* AOP 拦截所有 Page 实例的构造方法,重置初始值
* 覆盖手动 new Page() 的场景
*/
@Aspect
public static class PageConstructorAspect {
// 切入点:匹配 Page 类的所有构造方法执行后
@Pointcut("execution(com.mybatisflex.core.pagination.Page+.new(..))")
public void pageConstructorPointcut() {}
// 构造方法执行后重置值
@AfterReturning(pointcut = "pageConstructorPointcut()", returning = "page")
public void afterPageConstruct(Page<?> page) {
resetPageDefaultValue(page);
}
}
/**
* 通用方法:重置 Page 初始值为 0
*/
private static void resetPageDefaultValue(Page<?> page) {
if (page.getTotalPage() == -1) {
page.setTotalPage(0);
}
if (page.getTotalRow() == -1) {
page.setTotalRow(0);
}
}
}

View File

@@ -15,10 +15,7 @@
left join tb_shop_info s on o.shop_id = s.id
left join pp_package p on o.package_id = p.id
left join tb_user_info u on o.user_id = u.id
where 1=1
<if test="shopId != null">
and o.shop_id = #{shopId}
</if>
where o.shop_id = #{shopId}
<choose>
<!-- userId为空时拼接 and o.status != 'ing' -->
<when test="userId == null or userId == ''">