Java/Spring/BatchSqlUpdate

Материал из Java эксперт
Перейти к: навигация, поиск

Use BatchSqlUpdate To Insert 5000 Rows

   <source lang="java">
      

File: context.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"

      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xmlns:util="http://www.springframework.org/schema/util"
      xmlns:tx="http://www.springframework.org/schema/tx"
      xmlns:aop="http://www.springframework.org/schema/aop"
      xmlns:lang="http://www.springframework.org/schema/lang"
      xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
                          http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.0.xsd
                          http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd
                          http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
                          http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-2.0.xsd">
   <bean id="dataSource" class="org.apache.rumons.dbcp.BasicDataSource" destroy-method="close">
   <property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
   <property name="url" value="jdbc:hsqldb:mem:."/>
   <property name="username" value="sa"/>
   <property name="password" value=""/>
   </bean>
   <bean id="lobHandler" class="org.springframework.jdbc.support.lob.OracleLobHandler">
       <property name="nativeJdbcExtractor" ref="nativeJdbcExtractor"/>
   </bean>
   <bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.rumonsDbcpNativeJdbcExtractor"/>
   <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
       <property name="dataSource" ref="dataSource"/>
   </bean>

</beans>

File: Main.java import java.sql.Types; import javax.sql.DataSource; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.jdbc.core.SqlParameter; import org.springframework.jdbc.object.BatchSqlUpdate; class Main {

 public static void main(String args[]) throws Exception {
   ApplicationContext ac = new ClassPathXmlApplicationContext("context.xml", Main.class);
   DataSource dataSource = (DataSource) ac.getBean("dataSource");
   // DataSource mysqlDataSource = (DataSource) ac.getBean("mysqlDataSource");
   BatchInsert batchInsert = new BatchInsert(dataSource);
   int count = 5000;
   for (int i = 0; i < count; i++) {
     batchInsert.update(new Object[] { i + 100L, "a" + i, "b" + i, null });
   }
 }

} class BatchInsert extends BatchSqlUpdate {

 private static final String SQL = "insert into t_customer (id, first_name, last_name, last_login, "
     + "comments) values (?, ?, ?, ?, null)";
 BatchInsert(DataSource dataSource) {
   super(dataSource, SQL);
   declareParameter(new SqlParameter(Types.INTEGER));
   declareParameter(new SqlParameter(Types.VARCHAR));
   declareParameter(new SqlParameter(Types.VARCHAR));
   declareParameter(new SqlParameter(Types.TIMESTAMP));
   setBatchSize(10);
 }

}


      </source>