ibatis源码学习(一)整体设计和核心流程.docVIP

  • 0
  • 0
  • 约6.81万字
  • 约 62页
  • 2017-02-09 发布于重庆
  • 举报

ibatis源码学习(一)整体设计和核心流程.doc

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)

1亿VIP精品文档

相关文档