JDBC 连接数据库步骤

jdbc 连接数据库步骤

建立一个 jdbc 数据库连接共有四个步骤:

  • 导入 jdbc 包: 添加 import 语句到 java 程序导入所需的类在 java 代码中。
  • 注册 jdbc 驱动程序:这一步会导致 jvm 加载所需的驱动程序实现到内存中,因此它可以实现 jdbc 请求。
  • 制定数据库 url:这是创建格式正确的地址指向到要连接的数据库。
  • 创建连接对象:最后,代码调用 drivermanager 对象的 getconnection() 方法来建立实际的数据库连接。

 

1. 导入 jdbc 包

import 语句告诉java编译器在哪里可以找到在代码中引用,并放置在您的源代码最开始的类。

使用标准的jdbc包,它允许选择,插入,更新和sql表中删除数据,添加以下进口到您的源代码:

import java.sql.* ;  // for standard jdbc programs
import java.math.* ; // for bigdecimal and biginteger support

 

2. 注册 jdbc 驱动程序

使用 jdbc 创建连接之前,必须在程序中注册驱动程序。注册过程只能一次,可以通过以下两种方式之一注册一个驱动程序。

1)class.forname():

注册一个驱动程序中最常用的方法是使用 java 的 class.forname() 方法来动态加载驱动程序的类文件到内存中,它会自动将其注册。这种方法是可取的,因为它允许使驱动注册配置,便于携带。

下面的示例使用 class.forname() 来注册 oracle 驱动程序:

try {
   class.forname("oracle.jdbc.driver.oracledriver");
}
catch(classnotfoundexception ex) {
   system.out.println("error: unable to load driver class!");
   system.exit(1);
}

可以使用 getinstance() 方法来解决不兼容的jvm,但要编写了两个额外的例外情况如下:

try {
   class.forname("oracle.jdbc.driver.oracledriver").newinstance();
}
catch(classnotfoundexception ex) {
   system.out.println("error: unable to load driver class!");
   system.exit(1);
catch(illegalaccessexception ex) {
   system.out.println("error: access problem while loading!");
   system.exit(2);
catch(instantiationexception ex) {
   system.out.println("error: unable to instantiate driver!");
   system.exit(3);
}

2)drivermanager.registerdriver():

第二种注册驱动程序的方法是使用 static drivermanager.registerdriver() 方法。

下面的示例使用 registerdriver() 来注册oracle驱动程序:

try {
   driver mydriver = new oracle.jdbc.driver.oracledriver();
   drivermanager.registerdriver( mydriver );
}
catch(classnotfoundexception ex) {
   system.out.println("error: unable to load driver class!");
   system.exit(1);
}

 

3. 制定数据库 url

当加载驱动程序完成后,可以使用 drivermanager.getconnection() 方法获得连接。为方便参考,我们列出了三个重载 drivermanager.getconnection() 方法:

  • getconnection(string url)

  • getconnection(string url, properties prop)

  • getconnection(string url, string user, string password)

在这里,每个方法都需要一个数据库 url,它指向数据库地址。

下表列出了常用 jdbc 驱动程序名和数据库的 url。

rdbms jdbc驱动程序的名称 url 格式
mysql com.mysql.jdbc.driver jdbc:mysql://hostname:port/databasename
oracle oracle.jdbc.driver.oracledriver jdbc:oracle:thin:@hostname:port:databasename
db2 com.ibm.db2.jdbc.net.db2driver jdbc:db2:hostname:port/databasename
sybase com.sybase.jdbc.sybdriver jdbc:sybase:tds:hostname:port/databasename

 

3. 创建连接对象

1)使用数据库url的用户名和密码:

getconnection() 最常用的形式是 getconnection(string url, string user, string password),要求传递数据库 url,用户名 username和密码 password。

假设有一台主机tcp/ip地址 192.0.0.1 以及主机名和 oracle 监听器被配置为在端口 1521,数据库名称是 emp,然后完整的数据库 url 是:

jdbc:oracle:thin:@192.0.0.1:1521:emp

通过 url、username 和 password 三个参数来获得一个 connection 对象:

string url = "jdbc:oracle:thin:@192.0.0.1:1521:emp";
string user = "username";
string pass = "password"
connection conn = drivermanager.getconnection(url, user, pass);

2)只使用一个数据库 url 的调用方式

drivermanager.getconnection(string url);

通过一个参数来获得一个 connection 对象,在这种情况下,数据库的 url 中包含用户名和密码:

jdbc:oracle:driver:username/password@database

所以上面的连接可以创建如下:

string url = "jdbc:oracle:thin:username/password@192.0.0.1:1521:emp";
connection conn = drivermanager.getconnection(url);

3)使用数据库 url 和 properties 对象的调用方式

drivermanager.getconnection(string url, properties info);

properties 对象用来保存一组键值对,调用 getconnection() 方法时,将键值对传递给驱动程序。

import java.util.*;
string url = "jdbc:oracle:thin:@192.0.0.1:1521:emp";
properties info = new properties( );
info.put( "user", "username" );
info.put( "password", "password" );

connection conn = drivermanager.getconnection(url, info);

 

4. 关闭 jdbc 连接

在jdbc程序的结束,需要关闭所有的数据库连接,以结束数据库会话。但是,如果不关闭的话,java 垃圾收集器会关闭连接,并清除旧对象。但依托垃圾收集,特别是在数据库编程,是非常差的编程习惯,应该显式地关闭数据库连接。为了确保连接被关闭,可以在代码中的 finally 块执行。

要关闭上面打开的连接,应该调用close()方法,如下所示:

conn.close();

显式地关闭连接,可以节约系统资源。

相关文章