面试难点:Mybatis 中的 DAO 接口和 XML 文件里的 SQL 是如何建立关系的?
扫码关注“后端架构师”,选择“星标”公众号
重磅干货,第一时间送达!
责编:架构君 | 来源:blog.csdn.net/a745233700/article/details/89308762
责编:架构君 | 来源:blog.csdn.net/a745233700/article/details/89308762
上一篇好文:类加载子系统
大家好,我是后端架构师。
上一篇好文:类加载子系统
大家好,我是后端架构师。
假如我们有这样一个SQL:
<select id="getUserById" resultType="user">
select * from user
<where>
<if test="uid!=null">
and uid=#{uid}
</if>
</where>
</select>
它对应的SqlSource
对象看起来应该是这样的:
2、创建MappedStatement:
接下来,Mybatis会为XML中的每个SQL标签都生成一个MappedStatement
对象,这里面有两个属性很重要:
id:全限定类名+方法名组成的ID sqlSource:当前SQL标签对应的 SqlSource
对象
创建完的 MappedStatement
对象会被添加到 Configuration
中,Configuration
对象就是Mybatis中的大管家,基本所有的配置信息都维护在这里。当把所有的XML都解析完成之后,Configuration
就包含了所有的SQL信息。
全限定类名+方法名
” 找到 MappedStatement
对象,然后解析里面的SQL内容并进行执行即可。
二、Dao接口代理:
但是Dao接口并没有具体的实现类,那么在被调用时,最终又是怎样找到我们的SQL语句的呢?
首先,我们在Spring配置文件中,一般会这样配置:
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.viewscenes.netsupervisor.dao" />
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
或者你的项目是基于SpringBoot的,那么肯定也见过这种:@MapperScan("com.xxx.dao")
,
它们的作用是一样的,就是将包路径下的所有类注册到 Spring Bean 中,并将它们的beanClass
设置为 MapperFactoryBean
,MapperFactoryBean
实现了 FactoryBean
接口,俗称工厂Bean。那么,当我们通过 @Autowired
注入这个Dao接口时,返回的对象就是 MapperFactoryBean
这个工厂Bean中的 getObject()
方法对象。
那么,这个方法干了些什么呢?简单来说,它就是通过JDK动态代理,返回了一个Dao接口的代理对象 MapperProxy
,当我们通过 @Autowired
注入Dao接口时,注入的就是这个代理对象,我们调用 Dao接口中的方法时,则会调用到 MapperProxy
对象的invoke()
方法。
那么,目前为止,我们通过Dao接口也有了代理实现,所以就可以执行到它里面的方法了。
三、执行:
如上所述,当我们调用Dao接口方法的时候,实际调用到代理对象的invoke()
方法。在这里,实际上调用的就是SqlSession
里面的东西了。
public class DefaultSqlSession implements SqlSession {
public <E> List<E> selectList(String statement, Object parameter, RowBounds rowBounds) {
try {
MappedStatement ms = configuration.getMappedStatement(statement);
return executor.query(ms,
wrapCollection(parameter), rowBounds, Executor.NO_RESULT_HANDLER);
}
}
}
看到以上代码,说明我们想的不错。它就是通过statement
(全限定类型+方法名)拿到MappedStatement
对象,然后通过执行器Executor
去执行具体SQL并返回。
四、总结:
1、针对Mybatis中的Dao接口和XML文件里的SQL是如何建立关系的问题,主要可以归纳为下面几点小点:
SqlSource
以及动态标签SqlNodeMappedStatement
对象Spring 工厂Bean 以及动态代理 SqlSession
以及执行器
2、针对有两个XML文件和这个Dao建立关系是否会冲突的问题:不管有几个XML和Dao建立关系,只要保证namespace+id
唯一即可。
欢迎有需要的同学试试,如果本文对您有帮助,也请帮忙点个 赞 + 在看 啦!❤️
在 GitHub猿 还有更多优质项目系统学习资源,欢迎分享给其他同学吧!
PS:如果觉得我的分享不错,欢迎大家随手点赞、转发、在看。
最后给读者整理了一份BAT大厂面试真题,需要的可扫码加微信备注:“面试”获取。
版权申明:内容来源网络,版权归原创者所有。除非无法确认,我们都会标明作者及出处,如有侵权烦请告知,我们会立即删除并表示歉意。谢谢!
版权申明:内容来源网络,版权归原创者所有。除非无法确认,我们都会标明作者及出处,如有侵权烦请告知,我们会立即删除并表示歉意。谢谢!
END
最近面试BAT,整理一份面试资料《Java面试BAT通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。在这里,我为大家准备了一份2021年最新最全BAT等大厂Java面试经验总结。
别找了,想获取史上最全的Java大厂面试题学习资料
扫下方二维码回复「面试」就好了
历史好文:
基于SpringBoot 的CMS系统,拿去开发企业官网真香
SpringBoot+Netty+WebSocket 实现消息推送
称完全可替代 IntelliJ IDEA的国产IDE,牛逼呀 。。。
扫码关注“后端架构师”,选择“星标”公众号
别找了,想获取史上最全的Java大厂面试题学习资料
扫下方二维码回复「面试」就好了
历史好文:
基于SpringBoot 的CMS系统,拿去开发企业官网真香
SpringBoot+Netty+WebSocket 实现消息推送
称完全可替代 IntelliJ IDEA的国产IDE,牛逼呀 。。。
扫码关注“后端架构师”,选择“星标”公众号