当前位置: 首页 > ds >正文

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

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

核心前提

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

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

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

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

// 示例: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 接口中定义方法
public interface UserMapper {// 自定义查询方法,参数为 LambdaQueryWrapperList<User> findUsers(LambdaQueryWrapper<User> wrapper);
}
步骤2:编写 SQL 实现(两种方式)
  • XML 映射文件方式

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

    public interface UserMapper {@Select("SELECT * FROM user ${wrapper.getSqlSegment()}")List<User> findUsers(LambdaQueryWrapper<User> wrapper);
    }
    
步骤3:调用自定义方法
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),避免查询冗余字段。
http://www.xdnf.cn/news/18075.html

相关文章:

  • RK3588消费级8K VR一体机 是否有坑?
  • ABP vNext+ WebRTC DataChannel 低延迟传感推送
  • 《JMeter核心技术、性能测试与性能分析》 教学大纲及标准
  • JavaScript性能优化30招
  • Nacos-5--Nacos2.x版本的通信原理
  • C#---StopWatch类
  • 【开源大模型和闭源大模型分别有哪些?两者的对比?部署私有化模型的必要性有哪些?】
  • 五、ZooKeeper、Kafka、Hadoop、HBase、Spark、Flink集群化软件的部署
  • @Autowired @Resource IDE警告 和 依赖注入
  • 代码随想录刷题Day33
  • C#控制台输入(Read()、ReadKey()和ReadLine())
  • 关于simplifyweibo_4_moods数据集的分类问题
  • 企业级Spring事务管理:从单体应用到微服务分布式事务完整方案
  • 【CUDA 编程思想】FusedQKVProj-分组量化矩阵乘法高效实现全流程解析
  • IT资讯 | VMware ESXi高危漏洞影响国内服务器
  • 软考 系统架构设计师系列知识点之杂项集萃(123)
  • 怎样使用数据度量测试
  • Spring 条件注解与 SPI 机制(深度解析)
  • 社区物业HCommunity本地部署手册
  • 51单片机-驱动蜂鸣器模块教程
  • 力扣400:第N位数字
  • 我的学习认知、高效方法与知识积累笔记
  • 【Docker】搭建一个高性能的分布式对象存储服务 - MinIO
  • 国标调查:构建餐饮满意度动态优化体系,驱动体验价值升级​
  • Linux程序内存布局分析
  • rent8 安装部署教程之 Windows
  • Python采集微店商品详情 API 返回值说明,json数据返回
  • MySQL(多表查询练习)
  • 《嵌入式Linux应用编程(六):并发编程基础:多进程exec函数族及多线程基础》
  • swift多卡并行训练微调qwen3-8B