简介
一直以来都在使用mybatis,但却没有深入的了解下它,这么一款常用的持久层框架还是有必要翻翻源代码的。先上一张我自己初学mybatis的图。
当时一看这图,觉得mybatis全都懂了。。。,再把后来看过的mybatis资料图附上。
![](https://img-blog.csdnimg.cn/20210201151747120.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
![](https://img-blog.csdnimg.cn/20210201152027124.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dhbmd3XzIwMDc=,size_16,color_FFFFFF,t_70)
看完这些图立马觉得懂了。。。
浅析
话不多说直接看代码,就看官网的入门篇代码吧。
DataSource dataSource = BlogDataSourceFactory.getBlogDataSource();
TransactionFactory transactionFactory = new JdbcTransactionFactory();
Environment environment = new Environment("development", transactionFactory, dataSource);
Configuration configuration = new Configuration(environment);
configuration.addMapper(BlogMapper.class);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);
try (SqlSession session = sqlSessionFactory.openSession()) {
Blog blog = (Blog) session.selectOne("org.mybatis.example.BlogMapper.selectBlog", 101);
}
这就是mybatis最基本的使用了,从这里可以看出最重要的就是获取配置,然后拿着上层的API来执行sql就完了。这里我们就从mapper添加和sql执行两个方面谈谈。首先是mapper添加。
//Configuration
protected final MapperRegistry mapperRegistry = new MapperRegistry(this);
public <T> void addMapper(Class<T> type) {
mapperRegistry.addMapper(type);
}
//Mapperrigistry