日期:2014-05-16  浏览次数:20489 次

jdbc批量更新简单使用
前阵子做的一个lucene全文检索的小例子,里面涉及jdbc的批量更新,在此发布出来,与大家共享。
也是作为自己学习过程的复习和记录。

找个类的主要功能如下:
* 1. 读取包含专业词库的txt文件
* 2. 根据中文分词组件进行切分
* 3. split方法处理,返回字符串数组
* 4. 写出到txt文件输出
* 5. 使用sql批量更新方式插入数据库
*/


/**
 * 
 */
package net.tuolian.product.utils;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Date;

import jeasy.analysis.MMAnalyzer;

/**
 * @author sean
 * 
 * @since 2009/04/17
 * 1. 读取包含专业词库的txt文件
 * 2. 根据中文分词组件进行切分
 * 3. split方法处理,返回字符串数组
 * 4. 写出到txt文件输出
 * 5. 使用sql批量更新方式插入数据库
 */
public class JdbcBatchUpdate {

	static String sql = "insert into test04 values (?,?)";	
	Connection conn = null;
	PreparedStatement pstmt = null;

	/**
	 * @param args
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 * @throws IOException 
	 * @throws IllegalAccessException 
	 * @throws InstantiationException 
	 */
	public static void main(String[] args) throws SQLException,
			ClassNotFoundException, IOException, InstantiationException, IllegalAccessException {
		// TODO Auto-generated method stub
		JdbcBatchUpdate update = new JdbcBatchUpdate();
		update.init();
		
		//读取txt文件
		BufferedReader reader = new BufferedReader(new FileReader("keywordsource//output.txt"));
		
		//打开输出文件
		BufferedWriter writer = new BufferedWriter(new FileWriter("newoutput.txt"));
		
		String str = null;
		StringBuffer sb = new StringBuffer();
		
		while((str= reader.readLine())!=null){
			sb.append(str + " ");
		}
		//中文分词插件,JEAnalysis, 根据" "空格,将sb的字符串进行分词
		MMAnalyzer analyzer = new MMAnalyzer();
		String msg = analyzer.segment(sb.toString(), " ");		
		
		//将字符串更加空格进行分割,返回字符串数组
		String[] terms = msg.toString().split(" ");
		
		//输出到txt文件
		for(int i=0; i<terms.length;i++){
			System.out.println(i + terms[i]);
			writer.write(terms[i] + "\r\n");
		}
		writer.flush();
		writer.close();
		
		//执行mysql批量更新到数据库
		update.batchUpdate(terms);
		
		
	}
	
	/**
	 * 数据库连接初始化
	 * 1. 加载mysql jar包
	 * 2. 获得getConnection
	 * 3. 获得PreparedStatement
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public void init() throws SQLException, ClassNotFoundException{
		Class.forName("com.mysql.jdbc.Driver");
		conn = DriverManager.getConnection(
				"jdbc:mysql://localhost:3306/db_advertisement", "root", "root");
		conn.setAutoCommit(false);
		pstmt = (PreparedStatement) conn
				.prepareStatement(sql);
		System.out.println(new Date());
	}
	
	/**
	 * 批量更新
	 * 先加入批量, pstm.addBatch()
	 * 然后executeBatch(), 批量更新
	 * conmit(), 更新
	 * @param terms
	 * @throws SQLException
	 */
	public void batchUpdate(String[] terms) throws SQLException{		
		for (int i = 0; i < terms.length -1; i++) {			
			//此处注意setInt(1, i), 字段名称和栏目数必须匹配
			pstmt.setInt(1, i);
			pstmt.setString(2, terms[i]);
			pstmt.addBatch();
			System.out.println(i);
		}
		
//增加到批量工作任务中
		pstmt.executeBatch();
		System.out.println(new Date());
//提交执行
		conn.commit();
		pstmt.close();
		conn.close();
	}
}