- 0
- 0
- 约6.81万字
- 约 62页
- 2017-02-09 发布于重庆
- 举报
ibatis源码学习(一)整体设计和核心流程
本文主要从ibatis框架的基本代码骨架进行切入,理解ibatis框架的整体设计思路,各组件的实现细节将在后文进行分析。?背景?介绍ibatis实现之前,先来看一段jdbc代码:?
Java代码??
Class.forName(com.mysql.jdbc.Driver);??
String?url?=?jdbc:mysql://localhost:3306/learnworld;??
Connection?con?=?DriverManager.getConnection(url,?root,learnworld);???????????
String?sql?=?select?*?from?test;??
PreparedStatement?ps?=?con.prepareStatement(sql);?????????????
ResultSet?rs?=?ps.executeQuery();??
while(rs.next()){??
????System.out.println(id=?+?rs.getInt(1)+.?score=?+?rs.getInt(2));??
}??
上面这段代码大家比较熟悉,这是一个典型的jdbc方式处理流程: 建立连接-传递参数-sql执行-处理结果-关闭连接。?问题?上面的代码中包含了很多不稳定的因素,可能会经常发生修改:?1. 数据源和事务管理等?2. sql语句?3. 入参和结果处理?如果这些发生变化,我们需要直接修改代码,重新编译、打包、发布等。?DIY?下面从我们自己DIY的视角来考虑如何设计框架,应对这些问题。框架的核心思想是抽取共性,封装可能出现的变化。?如何处理数据源变化??将数据源连接等过程固定,将数据源中易变的信息封装在一起(如driverClassName, url等),放在配置文件中。?如何处理sql语句的变化??将sql语句统一放在配置文件中,为每条sql语句设置标识,在代码中使用标识进行调用。?如何应对入参和结果处理的变化??将参数传递,结果映射到java bean等统一封装在配置文件中。?结论: 将不变的流程固化到代码中,将变化的信息封装在配置文件中。?核心接口?ibatis抽取了以下几个重要接口:?1. SqlMapExecutor?该接口是对SQL操作行为的抽象,提供了SQL单条执行和批处理涉及的所有操作方法。??2. SqlMapTransactionManager?该接口是对事务行为的抽象,提供了事务执行过程中的涉及的所有方法。??3. SqlMapClient?该接口定位是SQL执行客户端,是线程安全的,用于处理多个线程的sql执行。它继承了上面两个接口,这意味着该接口具有SQL执行、批处理和事务处理的能力,如果你拥有该接口的实现类,意味着执行任何SQL语句对你来说是小菜一碟。该接口的核心实现类是SqlMapClientImpl。?4. SqlMapSession?该接口在继承关系上和SqlMapClient一致,但它的定位是保存单线程sql执行过程的session信息。该接口的核心实现类是SqlMapSessionImpl。?5. MappedStatement?该接口定位是单条SQL执行时的上下文环境信息,如SQL标识、SQL、参数信息、返回结果、操作行为等。?6. ParameterMap/ResultMap?该接口用于在SQL执行的前后提供参数准备和执行结果集的处理。?以上接口的类图关系如下(部分):??这里必须要强调SqlMapExecutorDelegate这个类,他是一个执行代理类,在ibatis框架中地位非常重要,因为他耦合了用户端的操作行为和执行环境,他持有执行操作的所需要的所有数据,同时管理着执行操作依赖的环境。?初始化过程?1. 读取和解析sqlmap配置文件。?2. 注册Statement对象。?3. 创建SqlMapClientImpl对象。?下面是一个Spring中sqlMapClient的bean配置:?
Java代码??
bean?id=sqlMapClient?class=org.springframework.orm.ibatis.SqlMapClientFactoryBean??
????property?name=dataSource?ref=dataSource?/??
????property?name=configLocation?value=classpath/sqlmap/sqlmap-ibatis.xml?/??
/bean??
下面看一下SqlMapClientFacto
原创力文档

文档评论(0)