Inside MyBatis3 -1

最简单的开始:

配置文件加载,与SqlSessionFactory的创建。

 

private static SqlSessionFactory sqlSessionFactory = null;
	
	static {
		String resource = "org/taobao/study/ibatis/Configuration.xml"; 
		
		Reader reader = null;
		try {
			reader = Resources.getResourceAsReader(resource);
		} catch (IOException e) {
			e.printStackTrace();
		}		
		
		sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
	}

 最简单的调用:

 

SqlSession session = Util.getSqlSessionFactory().openSession();
		User user = null;
		try{
			 user = (User)session.selectOne("org.taobao.study.ibatis.UserMapper.selectOne", id);
		}catch(Exception e){
			e.printStackTrace();
		}finally{
			session.close();
		}
		return user;

 开始猜测myBatis3内部代码:

第一步:解析配置文件,以及映射文件。

 

Resources.getResourceAsReader(resource);

 

第二步:使用映射逻辑,并实现基本数据调用。

 

 

 user = (User)session.selectOne("org.taobao.study.ibatis.UserMapper.selectOne", id);

内部应该还有JDBC的封装机制等。

 

接着跟踪第一部分:

 

sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
//  XMLConfigBuilder  ->   DefaultSqlSessionFactory
 

这个解析过程先是XMLConfigBuilder,内部用的是SAX,合理。然后给一个DefaultSqlSessionFactory的默认实现。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值