以下是按正常的数据库查询操作(没有做优化),代码如下:
package com.test.main;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import com.test.jdbc.OracleDBConnection;
public class Test {
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
//得到Oracle数据库连接
Connection conn=new OracleDBConnection().getConnection();
//conn.setAutoCommit(false);//设置为不自动提交
String sql="select licenseplateno,in_date, gps_time,longitude,latitude,height,speed,direction,eff,car_stat1,car_stat2"
+ " from GPS_LOG_cxc";
Statement stmt;
ResultSet resultSet;
//记录起始时间
long startTime=System.currentTimeMillis();
try {
stmt = conn.createStatement();
resultSet = stmt.executeQuery(sql);
String licenseplateno="";
long index =0;
while (resultSet.next()) {
++index;
licenseplateno=resultSet.getString(1);
System.out.println(index +">>"+licenseplateno);
}
resultSet.close();
stmt.close();
conn.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//记录结束时间
long endTime=System.currentTimeMillis();
//计算运行时间
long time=(endTime-startTime)/1000;
System.out.println("用时:"+time+"秒 ");
}
}
关于数据库连接
Connection conn=new OracleDBConnection().getConnection();
我是专门写了一个类OracleDBConnection,代码如下:
package com.test.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import com.test.jdbc.IDBConnection;
/**
* 取得Oracle数据库连接
* */
public class OracleDBConnection implements IDBConnection {
//DB Driver
private static final String DBDRIVER="oracle.jdbc.driver.OracleDriver";
//DB URL
private static final String DBURL="jdbc:oracle:thin:@192.168.95.86:1521:orcl";
//DB User
private static final String DBUSER="xxtmanage";
//DB Password
private static final String DBPASSWORLD="xxtinterface";
//DB Connection
private Connection conn=null;
//structor
public OracleDBConnection() {//在构造方法中进行数据库连接
System.out.println("OracleDBConnection.OracleDBConnection()");
try {
// 加载驱动程序
Class.forName(DBDRIVER);
//连接数据库
this.conn=DriverManager.getConnection(DBURL, DBUSER, DBPASSWORLD);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@Override
public Connection getConnection(){
System.out.println("OracleDBConnection.getConnection()");
return this.conn;
}
@Override
public void close(){
System.out.println("OracleDBConnection.close()");
if(this.conn!=null){
try {
this.conn.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
执行结果哪下:
19774887>>粤A434XX
19774888>>粤A434XX
19774889>>粤A434XX
19774890>>粤A434XX
19774891>>粤A434XX
19774892>>粤A434XX
19774893>>粤A434XX
19774894>>粤A434XX
19774895>>粤A434XX
19774896>>粤A434XX
19774897>>粤A434XX
19774898>>粤A434XX
19774899>>粤A434XX
19774900>>粤A434XX
19774901>>粤A434XX
用时:2367秒
注意:从以上程序可以看出,现在数据量只有2000万条不到,花费时间为2367/60=39.45分钟。速度让人很不满意,所以这就提出来了如何才能快速的读大批量数据呢???
解决方法,留待以后再补充。