JDBC数据库查询操作

5 篇文章 0 订阅
4 篇文章 0 订阅

以下是按正常的数据库查询操作(没有做优化),代码如下:

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分钟。速度让人很不满意,所以这就提出来了如何才能快速的读大批量数据呢???

解决方法,留待以后再补充。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值