<select id="page" resultType="com.ng8866.ngsale.starter.model.vo.biz.InformationVo"> select info.id, info.type_id, info.cover_image, info.title, info.author, info.summary, info.introduction, info.disable_image, info.pc_image, info.app_image, info.content, info.disable, info.pin, info.sort_by, info.url, type.name from ng_information info left join ng_information_type type on type.id =info.type_id <where> <if test="typeId != null"> info.type_id = #{typeId} </if> <if test="title != null and title != ''"> AND info.title LIKE CONCAT('%', #{title}, '%') </if> <if test="typeName != null and typeName != ''"> AND type.name LIKE CONCAT('%', #{typeName}, '%') </if> and info.del_flag = 1 </where> ORDER BY info.sort_by DESC LIMIT #{size} OFFSET #{current} </select>
时间: 2025-07-10 07:43:02 浏览: 17
<think>好的,我需要帮用户解决关于MyBatis动态SQL中使用条件判断和分页的示例问题。首先,用户提到了动态SQL的where和if条件,还有分页,所以我要确保覆盖这两个方面。
首先,我得回忆一下MyBatis的动态SQL标签。常用的有<where>、<if>,可能还有<choose>、<when>这些。用户需要根据不同的条件动态生成SQL,比如根据传入的参数是否存在来添加不同的查询条件。
然后是分页部分。用户可能想用MyBatis-Plus的分页功能,因为MyBatis本身需要手动处理分页,而MyBatis-Plus提供了方便的PageHelper或者内置的分页插件。需要确认用户是否使用MyBatis-Plus,但根据用户的问题,提到了MyBatis动态SQL,所以可能需要同时考虑原生MyBatis和MyBatis-Plus的情况。
接下来,我需要查找相关的示例。比如,在XML映射文件中如何使用<where>和<if>来构建动态查询条件。例如,当参数name不为空时,添加name的模糊查询;当age不为空时,添加age的条件。同时,分页部分可能需要使用RowBounds或者PageHelper插件,或者在MyBatis-Plus中使用Page对象和分页插件。
然后要考虑分页的正确配置。比如在MyBatis中,需要配置分页插件,例如在Spring Boot中通过@Configuration类来启用分页功能。同时,在Mapper接口中定义分页查询的方法,接收Page参数,并返回分页结果。
可能还需要注意SQL注入的问题,确保动态生成的SQL是安全的,使用预编译的参数。此外,分页参数如pageNum和pageSize的处理,以及如何将这些参数传递给Mapper方法。
用户可能还希望看到完整的代码示例,包括Controller、Service、Mapper层以及XML配置,这样他们可以全面了解如何实现动态查询和分页。同时,引用相关的参考资料,比如用户提供的引用[2]和[3],关于MyBatis-Plus的多表联查和分页方法,可以增强回答的可信度。
最后,需要验证示例的正确性,确保动态条件能够正确拼接,分页查询能够正确返回结果,并且没有语法错误。例如,检查XML中的动态SQL标签是否正确闭合,参数是否正确传递,分页配置是否生效等。</think>### MyBatis动态SQL示例(条件判断与分页)
#### 1. 动态条件查询(WHERE + IF)
在MyBatis XML映射文件中,通过`<where>`和`<if>`标签实现动态条件筛选:
```xml
<select id="selectUsers" resultType="User">
SELECT * FROM user
<where>
<if test="name != null and name != ''">
AND name LIKE CONCAT('%', #{name}, '%')
</if>
<if test="age != null">
AND age = #{age}
</if>
<if test="status != null">
AND status = #{status}
</if>
</where>
ORDER BY create_time DESC
</select>
```
*说明*:`<where>`标签自动处理条件前的AND/OR,避免语法错误[^2]。
#### 2. 分页实现(MyBatis-Plus)
结合MyBatis-Plus分页插件实现高效分页:
```java
// 配置分页插件
@Configuration
public class MyBatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
return interceptor;
}
}
// Service层实现
public Page<User> queryUsers(String name, Integer age, Integer pageNum, Integer pageSize) {
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.like(StringUtils.isNotBlank(name), "name", name)
.eq(age != null, "age", age);
return userMapper.selectPage(new Page<>(pageNum, pageSize), wrapper);
}
```
*特点*:自动生成分页SQL(LIMIT/OFFSET),支持多数据库方言[^3]。
#### 3. 原生MyBatis分页
通过`RowBounds`实现物理分页:
```java
List<User> users = sqlSession.selectList("selectUsers", params, new RowBounds(1, 10));
```
*注意*:需配合动态SQL使用,性能依赖数据库分页能力[^4]。
阅读全文
相关推荐


















