程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> MYSQL批量插入數據的實現代碼

MYSQL批量插入數據的實現代碼

編輯:JAVA編程入門知識
@echo off
cls
set CLASSPATH=..\api\jogre.jar
set CLASSPATH=%CLASSPATH%;.
set CLASSPATH=%CLASSPATH%;classes
set CLASSPATH=%CLASSPATH%;lib\dom4j.jar
java org.jogre.server.JogreServer
建表
代碼如下:

create database con_test;
use con_test;
create table test(id int not null,txt varchar (70),primary key (id),index (id));

就兩個字段,id加索引。
用java程序給表循環10萬次插入紀錄,id(循環次數) 和 內容(這條記錄是第=xx)
InsertTestMysql.java
代碼如下:

import java.lang.*;
import java.sql.*;
public class InsertTestMysql{
public static void main(String [] args){
java.util.Date now_start = new java.util.Date();
long start_time=now_start.getTime();
int st = 100000;
String str,info;
String db="org.gjt.mm.mysql.Driver";
String host="jdbc:mysql://192.168.1.35/test";
String user="root";
String passwd="root";
Connection con=null;
try{
Class.forName(db).newInstance();
}
catch(Exception e){
System.out.println("加載驅動失敗:"+db);
}
try{
con=DriverManager.getConnection(host,user,passwd);
con.setAutoCommit(false);//關閉事務自動提交
for (int i=1;i<=st;i++){
info = "這條記錄是第=";
info = info.concat(java.lang.Integer.toString(i));
str = "insert into test (id,txt) values(?,?);";
PreparedStatement pstmt = con.prepareStatement(str);
pstmt.setInt(1,i);
pstmt.setString(2,info);
pstmt.executeUpdate();
}
con.commit();//語句執行完畢,提交本事務
con.close();
}
catch(Exception e) {
System.out.println(e);
}
java.util.Date now_end = new java.util.Date();
long end_time=now_end.getTime();
long use_time=end_time-start_time;
System.out.println("<<---本頁生成耗時["+use_time+"]毫秒("+((double)use_time)/1000+"秒)--->>");
System.out.println("\n<<---共插入記錄"+st+"條-->>");
}
}

在不同版本的jdbc下,表現不同。
jdbc 3.1.7, 12770,12778 插入這個數目時,程序退出,中文正常。
jdbc 3.1.12 12000 插入這個數目時,程序退出,中文正常。
均出現以下提示:
"Exception in thread "main" java.lang.OutOfMemoryError: Java heap space"
“Java 堆 空間 錯誤”,可能是我機器內存不夠。但用3.10系列jdbc就正常。
jdbc 3.0.16-ga 10萬記錄正常,中文正常。
jdbc 3.0.10 10萬記錄成功,但中文錯誤。
使用3.1系列jdbc,程序運行後,機器剩余物理內存很快就成了40xxKB了。
這個,也可能是jdbc3.1系列需要內存大,我機器內存不足。
明天再去同學的AMD64 512M RAM 機器測試。
jdbc 3.0.16-ga 唯一這個正常的,測試結果為:
代碼如下:

D:\Program Files\test\db_test>java InsertTestMysql
<<---本頁生成耗時[98582]毫秒(98.582秒)--->>
<<---共插入記錄100000條-->>

前幾天又測試了下,用開源的jdts 的jdbc 連接ms-sql server 2000 sp3 其他同上,測試結果慘不忍睹:
代碼如下:

D:\dev\java\src\ts\Ms-Sql>java InsertTestMssql
<<---本頁生成耗時[1746681]毫秒(1746.681秒)--->>
<<---共插入記錄100000條-->>

  • 首頁
  • 上一頁
  • 1
  • 2
  • 3
  • 下一頁
  • 尾頁
  • 共3頁
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved