您的位置:首页 > 编程语言 > Java开发

Java程序连接数据库的四种方法

2013-01-05 20:53 190 查看
1.Java程序连接数据库的四种方法

1
JDBC-ODBC桥和ODBC驱动程序--在这种方式下,这是一个本地解决方案,因为ODBC驱动程序和桥代码必须出现在用户的每台机器中。从根本上说这是一个临时解决方案。

2 本机代码和Java驱动程序--它用另一个本地解决方案(该平台上的Java可调用的本机代码)取代
ODBC 和 JDBC-ODBC 桥。

3
JDBC网络的纯Java驱动程序--由Java驱动程序翻译的JDBC形成传送给服务器的独立协议。然后,服务器可连接任何数量的数据库。这种方法使您可能从客户机Applet中调用服务器,并将结果返回到您的Applet。在这种情况下,中间件软件提供商可提供服务器。

4 本机协议Java驱动程序--
Java驱动程序直接转换为该数据库的协议并进行调用。这种方法也可以通过网络使用,而且可以在Web浏览器的Applet中显示结果。在这种情况下,每个数据库厂商将提供驱动程序。

2.使用连接池和语句池 提高 Oracle 驱动的 JDBC
程序的性能


使用诸如连接池和语句池等池技术可以显著提高数据库密集型应用程序的性能,因为这样可以实现对象重用,而无需花费时间和资源重新创建对象。

如果应用程序与数据库频繁交互并且经常使用相同的参数重新建立连接,那么重用表示应用程序使
用的物理数据库连接的数据库连接对象可显著提高性能。反之,如果应用程序与其基础数据库很少连接,您不会因使用连接池获益。实际上,如果池的设置(例如,允许的最大或最小连接数限制)针对特定应用程序进行了优化,许多数据库密集型应用程序都可以因使用连接池获益。

与连接池一样,语句池也是用于提高应用程序性能的技术。通过在应用程序运行期间多次执行语句池,可以进一步提高性能。然而,我们应该意识到语句池并不是解决性能问题的灵丹妙药。如果对每条语句进行缓存而不辨别其在程序中执行的次数,则不可能获得任何性能改进。实际上,由于将语句放入缓存并保存在缓存中将产生开销,因此对在程序执行期间仅执行一次的语句进行缓存将降低性能。

3.准备好驱动和连接池

准备数据库驱动:

由于安装的数据库是oracle10g个人版,这里下载的是oracle10g瘦版JDBC(相当于前面Java数据库连接方式的第四种)地址是:
http://www.oracle.com/technology/software/tech/java/sqlj_jdbc/htdocs/jdbc_10201.html
准备数据库连接池

DBCP是apache的数据库连接池项目,其依赖于commons-pool 下载地址是:

http://commons.apache.org/dbcp/download_dbcp.cgi

http://commons.apache.org/pool/downloads.html

4.初始化连接代码

Java代码



import org.apache.commons.dbcp.BasicDataSource;

import java.sql.SQLException;

import java.sql.Connection;

public class Dbcp extends DBConnection

{

private BasicDataSource dataSource = null;

// 初始化数据连接

public void initDataSource()

{

if (dataSource != null)

{

try

{

dataSource.close();

}

catch (Exception e)

{

e.printStackTrace();

}

dataSource = null;

}

try

{

dataSource = new BasicDataSource();

dataSource.setDriverClassName("oracle.jdbc.driver.OracleDriver");

dataSource.setUrl("jdbc:oracle:thin:@127.0.0.1:1521:XE");

dataSource.setUsername("name");

dataSource.setPassword("password");

dataSource.setMaxActive(20);

dataSource.setMaxIdle(10);

}

catch (Exception e)

{

e.printStackTrace();

}

}

// 从连接池中获得数据库连接

public Connection getConnection() throws SQLException

{

if (dataSource != null)

{

return dataSource.getConnection();

}

else

{

throw new SQLException("数据源不存在");

}

}

}

5.测试代码

Java代码
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: