欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MYSQL批量插入数据的实现代码第1/3页

程序员文章站 2022-07-22 13:45:07
@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条-->>

1