MyBatis源码分析(三)批量更新

主要是org.apache.ibatis.executor.BatchExecutor这个类,此类继承BaseExecutor(基本增删改查,缓存,懒加载处理)
BatchExecutor这个类有四个属性

  //批处理更新最大返回结果 
public static final int BATCH_UPDATE_RETURN_VALUE = Integer.MIN_VALUE + 1002;
//存放声明(命令)对象集合
  private final List<Statement> statementList = new ArrayList<Statement>();
// 批处理结果集合
  private final List<BatchResult> batchResultList = new ArrayList<BatchResult>();
//当前sql语句
  private String currentSql;

 一个带参数构造函数,传入配置信息和事务对象

public BatchExecutor(Configuration configuration, Transaction transaction) {
super(configuration, transaction);
}

重写了三个方法, 1.更新方法  2.查询方法 3.刷新方法
我们来看批量更新doUpdate

public int doUpdate(MappedStatement ms, Object parameterObject)
throws SQLException {
Configuration configuration = ms.getConfiguration();
StatementHandler handler = configuration.newStatementHandler(this, ms, parameterObject, RowBounds.DEFAULT, null);
BoundSql boundSql = handler.getBoundSql();
String sql = boundSql.getSql();
Statement stmt;
if (currentSql != null && sql.hashCode() == currentSql.hashCode() && sql.length() == currentSql.length()) {
int last = statementList.size() - 1;
stmt = statementList.get(last);
} else {
Connection connection = transaction.getConnection();
stmt = handler.prepare(connection);
currentSql = sql;
statementList.add(stmt);
batchResultList.add(new BatchResult(ms, sql, parameterObject));
}
handler.parameterize(stmt);
handler.batch(stmt);
return BATCH_UPDATE_RETURN_VALUE;
}

  最重要一句话就是handler.batch(stmt),实际上就是stmt.addBatch();
举个小例子来说明:

//记录1
stmt.setInt(1, 1); 
stmt.setString(2, "Cujo"); 
stmt.addBatch(); 

//记录2
stmt.setInt(1, 2); 
stmt.setString(2, "Fred"); 
stmt.addBatch(); 

//记录3
stmt.setInt(1, 3); 
stmt.setString(2, "Mark"); 
stmt.addBatch(); 

//批量执行上面3条语句
int [] counts = statement.executeBatch(); 

//Commit it 
connection.commit();

 

如果项目中要用到批量更新如何使用?
下面的映射文件,假设namespace="com.dao.Stuent"

<insert id="insertbatch" parameterType="java.util.List"> 
<selectKey keyProperty="fetchTime" order="BEFORE" 
resultType="java.lang.String"> 
SELECT CURRENT_TIMESTAMP() 
</selectKey> 
insert into kangaiduoyaodian ( depart1, depart2, product_name, 
generic_name, img, product_specification, unit, 
approval_certificate, manufacturer, marketPrice, vipPrice, 
website, fetch_time, productdesc ) values 
<foreach collection="list" item="item" index="index" 
separator=","> 
( #{item.depart1}, #{item.depart2}, #{item.productName}, 
#{item.genericName}, #{item.img}, 
#{item.productSpecification}, #{item.unit}, 
#{item.approvalCertificate}, #{item.manufacturer}, 
#{item.marketprice}, #{item.vipprice}, #{item.website}, 
#{fetchTime}, #{item.productdesc} ) 
</foreach> 
</insert> 

 调用:  SqlSession session = factory.openSession(ExecutorType.BATCH); //关键是这句

原文: http://www.ibatis3.com/thread-111-1-1.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis是一款优秀的持久层框架,其主要作用是简化SQL语句的编写,提高数据访问效率。MyBatis的核心原理主要由以下个部分组成: 1. SqlSessionFactory SqlSessionFactory是MyBatis的核心接口,其主要作用是创建SqlSession对象。SqlSession是MyBatis与数据库交互的工具,用于执行SQL语句、管理事务等操作。SqlSessionFactory的创建过程主要包括以下几个步骤: (1)读取mybatis-config.xml配置文件,解析其中的配置信息。 (2)读取Mapper.xml映射文件,解析其中的SQL语句和参数信息。 (3)构建Configuration对象,将解析出的配置信息封装到该对象中。 (4)创建SqlSessionFactory对象,将Configuration对象作为参数传入。 2. Mapper接口 Mapper接口是MyBatis中定义SQL语句的主要方式,其定义了与数据库交互的方法。在Mapper接口中定义的方法可以直接调用SqlSession中的方法来执行SQL语句。Mapper接口的定义方式主要有两种: (1)XML映射文件定义方式:将SQL语句和参数信息写在Mapper.xml文件中,然后在Mapper接口中定义方法,方法名与Mapper.xml文件中定义的SQL语句id保持一致。 (2)注解定义方式:直接在Mapper接口的方法上使用@Select、@Insert、@Update等注解定义SQL语句和参数信息。 3. Executor Executor是MyBatis中执行SQL语句的核心组件,其主要作用是处理SQL语句的执行和结果的返回。Executor主要包括以下几个实现类: (1)SimpleExecutor:简单执行器,每次执行SQL语句都会创建一个Statement对象。 (2)ReuseExecutor:可重用执行器,每次执行SQL语句不会创建新的Statement对象,而是从缓存中获取已经创建的Statement对象。 (3)BatchExecutor:批量执行器,将多个SQL语句批量执行,减少与数据库的交互次数,提高执行效率。 总体来说,MyBatis的核心原理主要包括SqlSessionFactory的创建、Mapper接口的定义和Executor的执行。通过这个部分的协作,MyBatis可以轻松地实现与数据库的交互。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值