
揭秘 MyBatis-Plus List 查询返回类型差异
在使用 MyBatis-Plus 时,开发人员可能会遇到这样的疑惑:为何 list 查询返回的不是直接的结果,而是一个类型?
这个问题源于最近的一篇在线提问。提问者想返回一个结果集,其中引用了同一依赖项,但查询结果却不同。
针对这一疑惑,一位专家回应道:“这很有趣。去掉业务逻辑,做一个 demo 让大家看看,因为按理说不会出现这种情况。”
深入分析
MyBatis-Plus 是一个 MyBatis ORM 框架的增强版本,它提供了对 JDBC 的简化操作和对象关系映射。在执行 list 查询时,MyBatis-Plus 将查询结果映射为指定类型的对象或集合。
通常情况下,MyBatis-Plus 会根据泛型或 mapper 方法返回类型自动确定目标类型。如果指定了泛型,则返回对象或对象集合。否则,返回 Map 或 Map 集合。
为什么会出现差异?
出现这种差异的原因可能是:
- 配置错误:确保 mapper 方法或类上的泛型正确指定。
- 继承关系:如果对象继承自其他对象,则 mapper 返回类型应为父对象类型。
- 自定义 Mapper:如果使用自定义 Mapper,请检查 Mapper 实现是否正确映射结果。
- MyBatis 拦截器:某些 MyBatis 拦截器可能会修改查询结果。检查是否启用了此类拦截器。
进一步排查
要进一步排查问题,建议进行以下操作:
- 创建一个简单的 demo,去掉所有业务逻辑。
- 检查 mapper 接口和实现的泛型或返回类型。
- 禁用任何可能影响查询结果的拦截器。
- 检查日志文件以获取有关查询执行的更多信息。










