Mybatis typealiaspackage 通配符扫描方法

本文介绍了一个Mybatis的拦截器MybatisJsonInterceptor,它用于将查询结果直接转换为JSON格式。通过判断SQL语句并解析字段别名,将结果集转化为键值对的List,方便前端展示。

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.youkuaiyun.com/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

                最近两天项目需求研究了一下mybatis拦截器。对于Mybatis拦截器发现其功能强大,虽很灵活但是其内部对象转换太麻烦很多接口没有完全暴露出来。甚至不得不通过反射的方式去取其内部关联对象。可能Mybatis也不希望用户直接对其内部Statement,以及ResultSetHandler等进行操作。那这样与直接JDBC又有何区别呢? 

通用查询其实也并非完全通用。只能是稍微的简化一下代码,减少程序员一些重复的工作罢了。本项目采用springMVC + Mybatis + EasyUi 进行构建。设想一种应用场景。我一个统计查询:统计四张表里不同数据,或者多表关联查询:从A表当中查询三个字段,从B表当中查询二个字段,从C表当中查询一个字段,从D表当中查询两个字段。这种场景对于Mybaits来说。几张表的关联查询比较头痛。两种方式,一种是建立实体对象(VO)多表关联查询然后建立映射。返回其VO实体类。另一种方式通过对象关联的方式,Mapper.xml里进行配置。两种方式在此不作讨论。(PS:如有高手有更好的方式解决这种场景请不吝赐教) 

本文主要讨论通过Mybatis拦截器实现直接取其 ResultSet 通过约定的SQL语句格式解析后生成数据格式。或者直接JSON化传给前台以作展示。 

拦截器: 

    由于我们不关心对象与字段的映射关联。所以我们只需要在 ResultSetHandler 当中进行拦截就行了,拦截其handleResultSets方法。 

直接上代码: 

Java代码   收藏代码
  1. /* 
  2.  * E2ESQM-W 业务端故障诊断系统  
  3.  * FileName:MybatisPageInterceptor.java 
  4.  * Company: ZZNode Technology Co., Ltd. 
  5.  */  
  6. package com.zznode.e2esqm.core.commons;  
  7.   
  8. import java.lang.reflect.Field;  
  9. import java.sql.ResultSet;  
  10. import java.sql.Statement;  
  11. import java.util.ArrayList;  
  12. import java.util.HashMap;  
  13. import java.util.List;  
  14. import java.util.Map;  
  15. import java.util.Properties;  
  16.   
  17. import org.apache.ibatis.executor.resultset.ResultSetHandler;  
  18. import org.apache.ibatis.mapping.BoundSql;  
  19. import org.apache.ibatis.plugin.Interceptor;  
  20. import org.apache.ibatis.plugin.Intercepts;  
  21. import org.apache.ibatis.plugin.Invocation;  
  22. import org.apache.ibatis.plugin.Plugin;  
  23. import org.apache.ibatis.plugin.Signature;  
  24.   
  25. /** 
  26.  * Mybatis直接返回JS
MyBatis 中,配置 `@MapperScan` 扫描 Mapper 接口是实现与 Spring 集成时的重要步骤。通过该注解,可以将指定包路径下的接口自动注册为 Spring 容器中的 Bean,并生成对应的代理对象以供调用。 ### 配置类中使用 `@MapperScan` 可以在一个标注了 `@Configuration` 的配置类上添加 `@MapperScan` 注解,用于指定需要扫描的 Mapper 接口所在的包路径。这种方式适用于需要将 Mapper 配置与其他配置分离的情况。例如: ```java import org.springframework.context.annotation.Configuration; import org.mybatis.spring.annotation.MapperScan; @Configuration @MapperScan("com.example.projectDemo.mapper") // 指定扫描的 Mapper 包路径 public class MyBatisConfig { // 这里可以定义其他 MyBatis 配置 } ``` 在这种方式下,Spring 会扫描 `com.example.projectDemo.mapper` 包下的所有接口,并将其注册为容器中的 Bean [^1]。 ### 默认的自动扫描机制 如果没有显式地配置 `@MapperScan`,MyBatis 在 Spring Boot 环境中仍然可以通过默认的自动配置机制完成 Mapper 的扫描。具体来说,`AutoConfiguredMapperScannerRegistrar` 这个 Bean 会在 Spring Boot 启动时自动扫描与主应用类同级或子级包中的 Mapper 接口 [^2]。 这意味着如果 Mapper 接口位于 Spring Boot 主类所在包或其子包下,则无需额外配置即可被自动发现和注册。 ### `@MapperScan` 注解的工作原理 当使用 `@MapperScan` 注解时,MyBatis 会解析该注解中指定的包路径,并扫描这些路径下的接口。对于每个符合要求的接口(通常是带有 `@Mapper` 注解的接口),Spring 会为其创建一个 `GenericBeanDefinition`,并设置其 `Class` 属性为 `MapperFactoryBean`。最终,这些定义会被注册到 Spring 的 IOC 容器中 [^3]。 注入过程中,Spring 会根据 `getObjectType()` 方法匹配接口的类型,并通过 `getObject()` 方法生成接口的代理对象 [^4]。 ### 包路径的通配符使用 关于 `@MapperScan` 中的路径配置,需要注意的是,通配符 `*` 只能代表一级包名。例如,`@MapperScan("com.demo.*.mapper")` 可以扫描到 `com.demo.aaa.mapper`,但无法扫描到 `com.demo.aaa.bbb.mapper` [^5]。 因此,在实际开发中,应根据项目的包结构合理选择扫描路径,以确保所有的 Mapper 接口都能被正确加载。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值