MYSQL批量插入数据的实现代码第1/3页
程序员文章站
2023-11-25 09:57:16
@echo off cls set classpath=..\api\jogre.jar set classpath=%classpath%;. set classpath...
@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条-->>
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
上一篇: C#用链式方法表达循环嵌套
下一篇: C# IsDefined的问题