MYSQL批量插入資料的實現代碼第1/3頁_java

來源:互聯網
上載者:User
@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/3頁  123下一頁閱讀全文
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.