【解决笔记】MyBatis-Plus 中无 selectList 方法

MyBatis-Plus 中无 selectList 方法的解决笔记

核心前提

MyBatis-Plus 的 BaseMapper 接口内置了 selectList 等基础查询方法,继承该接口可直接使用,无需手动实现。

无 selectList 方法的两种情况及解决方式

1. 未继承 BaseMapper(推荐方案)

让 Mapper 接口继承 BaseMapper<T>(T 为实体类),即可直接获得 selectList 等基础方法:

java 复制代码
// 示例:UserMapper 继承 BaseMapper<User>
public interface UserMapper extends BaseMapper<User> {
    // 无需手动定义 selectList,BaseMapper 已包含
}

// 使用方式
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(User::getName, "张三");
List<User> users = userMapper.selectList(wrapper); // 直接调用

2. 无法继承 BaseMapper(特殊场景,需自定义方法)

步骤1:在 Mapper 接口中定义方法
java 复制代码
public interface UserMapper {
    // 自定义查询方法,参数为 LambdaQueryWrapper
    List<User> findUsers(LambdaQueryWrapper<User> wrapper);
}
步骤2:编写 SQL 实现(两种方式)
  • XML 映射文件方式

    xml 复制代码
    <!-- UserMapper.xml -->
    <select id="findUsers" resultType="com.example.entity.User">
        SELECT * FROM user
        <!-- 引入 LambdaQueryWrapper 生成的条件片段 -->
        ${wrapper.getSqlSegment()}
    </select>
  • 注解方式

    java 复制代码
    public interface UserMapper {
        @Select("SELECT * FROM user ${wrapper.getSqlSegment()}")
        List<User> findUsers(LambdaQueryWrapper<User> wrapper);
    }
步骤3:调用自定义方法
java 复制代码
LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(User::getName, "张三");
List<User> users = userMapper.findUsers(wrapper); // 调用自定义方法

注意事项

  1. 优先选择继承 BaseMapper,这是 MyBatis-Plus 的核心特性,可大幅简化开发。
  2. 自定义方法时,通过 ${wrapper.getSqlSegment()} 引入查询条件,MyBatis-Plus 已对 SQL 注入做了防护。
  3. 若需灵活控制查询字段,可在 SQL 中指定具体列(如 SELECT id, name FROM user),避免查询冗余字段。