fix: 带子查询的场景下,分页优化误删 join 的修复

This commit is contained in:
cybzzz 2025-11-15 13:24:36 +08:00
parent ed09906361
commit 9343c8eabd
2 changed files with 25 additions and 6 deletions

View File

@ -76,7 +76,8 @@ public class OperatorSelectCondition extends QueryCondition {
@Override @Override
boolean containsTable(String... tables) { boolean containsTable(String... tables) {
QueryCondition condition = queryWrapper.getWhereQueryCondition(); QueryCondition condition = queryWrapper.getWhereQueryCondition();
return condition != null && condition.containsTable(tables); boolean subContains = condition != null && condition.containsTable(tables);
return subContains || nextContainsTable(tables);
} }
@Override @Override

View File

@ -31,11 +31,7 @@ import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import static com.mybatisflex.core.query.QueryMethods.case_; import static com.mybatisflex.core.query.QueryMethods.*;
import static com.mybatisflex.core.query.QueryMethods.column;
import static com.mybatisflex.core.query.QueryMethods.count;
import static com.mybatisflex.core.query.QueryMethods.distinct;
import static com.mybatisflex.core.query.QueryMethods.select;
import static com.mybatisflex.test.model.table.RoleTableDef.ROLE; import static com.mybatisflex.test.model.table.RoleTableDef.ROLE;
import static com.mybatisflex.test.model.table.UserRoleTableDef.USER_ROLE; import static com.mybatisflex.test.model.table.UserRoleTableDef.USER_ROLE;
import static com.mybatisflex.test.model.table.UserTableDef.USER; import static com.mybatisflex.test.model.table.UserTableDef.USER;
@ -199,4 +195,26 @@ class QueryWrapperTest {
" AND ` user_name ` = ''", sql); " AND ` user_name ` = ''", sql);
} }
@Test
void test07() {
QueryWrapper queryWrapper = QueryWrapper.create()
.select()
.from(USER.as("u"))
.leftJoin(USER_ROLE).as("ur").on(USER.USER_ID.eq(USER_ROLE.USER_ID))
.where(QueryCondition.createEmpty())
.and(USER.USER_ID.eq(1).or(USER.USER_ID.in(
QueryWrapper.create().select(USER_ROLE.USER_ID).from(USER_ROLE)))
)
.and(
exists(selectOne().from(ROLE)
.where(ROLE.ROLE_ID.eq(USER_ROLE.ROLE_ID)))
)
.and(USER_ROLE.USER_ID.eq(1));
System.out.println(queryWrapper.toSQL());
QueryCondition whereQueryCondition = CPI.getWhereQueryCondition(queryWrapper);
boolean contained = CPI.containsTable(whereQueryCondition, "tb_user_role");
Assertions.assertTrue(contained);
}
} }