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();
显式地关闭连接,可以节约系统资源。