@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條-->>