Java编程中使用JDBC API连接数据库和创建程序的方法
JDBC连接数据库
涉及到建立一个JDBC连接的编程是相当简单的。下面是这些简单的四个步骤:
- 导入JDBC包:添加import语句到Java程序导入所需的类在Java代码中。
- 注册JDBC驱动程序:这一步会导致JVM加载所需的驱动程序实现到内存中,因此它可以实现JDBC请求。
- 数据库URL制定:这是创建格式正确的地址指向到要连接的数据库。
- 创建连接对象:最后,代码调用DriverManager对象的getConnection()方法来建立实际的数据库连接。
导入JDBC包:
import语句告诉Java编译器在哪里可以找到在代码中引用,并放置在您的源代码最开始的类。
使用标准的JDBC包,它允许选择,插入,更新和SQL表中删除数据,添加以下进口到您的源代码:
importjava.sql.*;//forstandardJDBCprograms importjava.math.*;//forBigDecimalandBigIntegersupport
注册JDBC驱动程序:
使用它之前,必须注册你的驱动程序在程序。注册驱动程序是由Oracle驱动程序的类文件被加载到内存中以便它可以被用作JDBC接口的实现过程。
需要做这个注册只能在你的程序一次。可以通过以下两种方式之一注册一个驱动程序。
方法(I)-Class.forName():
注册一个驱动程序中最常用的方法是使用Java的Class.forName()方法来动态加载驱动程序的类文件到内存中,它会自动将其注册。这种方法是可取的,因为它允许使驱动注册配置,便于携带。
下面的示例使用Class.forName()来注册Oracle驱动程序:
try{ Class.forName("oracle.jdbc.driver.OracleDriver"); } catch(ClassNotFoundExceptionex){ System.out.println("Error:unabletoloaddriverclass!"); System.exit(1); }
可以使用getInstance()方法来解决不兼容的JVM,但要编写了两个额外的例外情况如下:
try{ Class.forName("oracle.jdbc.driver.OracleDriver").newInstance(); } catch(ClassNotFoundExceptionex){ System.out.println("Error:unabletoloaddriverclass!"); System.exit(1); catch(IllegalAccessExceptionex){ System.out.println("Error:accessproblemwhileloading!"); System.exit(2); catch(InstantiationExceptionex){ System.out.println("Error:unabletoinstantiatedriver!"); System.exit(3); }
方法(二)-DriverManager.registerDriver():
可以用它来注册一个驱动程序的第二种方法是使用staticDriverManager.registerDriver()方法。
应该,如果使用的是不兼容的JDKJVM,比如微软提供一个使用registerDriver()方法。
下面的示例使用registerDriver()来注册Oracle驱动程序:
try{ DrivermyDriver=neworacle.jdbc.driver.OracleDriver(); DriverManager.registerDriver(myDriver); } catch(ClassNotFoundExceptionex){ System.out.println("Error:unabletoloaddriverclass!"); System.exit(1); }
数据库URL制定:
当加载的驱动程序,可以建立程序中使用DriverManager.getConnection()方法的连接。为方便参考,让列出了三个重载DriverManager.getConnection()方法:
- getConnection(Stringurl)
- getConnection(Stringurl,Propertiesprop)
- getConnection(Stringurl,Stringuser,Stringpassword)
在这里,每个表单需要一个数据库URL。数据库的URL是指向数据库地址。
制定一个数据库URL是大多数用在建立连接相关。
下表列出了下来流行的JDBC驱动程序名和数据库的URL。
RDBMS JDBC驱动程序的名称 URL格式
MySQLcom.mysql.jdbc.Driverjdbc:mysql://hostname/databaseName ORACLEoracle.jdbc.driver.OracleDriverjdbc:oracle:thin:@hostname:portNumber:databaseName DB2COM.ibm.db2.jdbc.net.DB2Driverjdbc:db2:hostname:portNumber/databaseName Sybasecom.sybase.jdbc.SybDriverjdbc:sybase:Tds:hostname:portNumber/databaseName
以URL格式所有高亮的部分是静态的,需要改变只剩余部分按照数据库设置。
创建连接对象:使用数据库URL的用户名和密码:
下面三种形式DriverManager.getConnection()方法来创建一个连接对象。getConnection()最常用形式要求传递一个数据库URL,用户名username和密码password:
对URL数据库部分databaseName的值:假设使用的是Oracle的瘦驱动程序,需要指定一个主机:端口。
假设有一台主机TCP/IP地址192.0.0.1以及主机名和Oracle监听器被配置为在端口1521,数据库名称是EMP,然后完整的数据库URL是:
jdbc:oracle:thin:@amrood:1521:EMP
现在,必须调用适当的用户名和密码以及getConnection()方法来获得一个Connection对象,如下所示:
StringURL="jdbc:oracle:thin:@amrood:1521:EMP"; StringUSER="username"; StringPASS="password" Connectionconn=DriverManager.getConnection(URL,USER,PASS);
只使用一个数据库URL:
第二种形式DriverManager.getConnection()方法只需要一个数据库URL:
DriverManager.getConnection(Stringurl);
然而,在这种情况下,数据库的URL,包括用户名和密码,并具有以下的一般形式:
jdbc:oracle:driver:username/password@database
所以上面的连接可以创建如下:
StringURL="jdbc:oracle:thin:username/password@amrood:1521:EMP"; Connectionconn=DriverManager.getConnection(URL);
使用数据库的URL和一个Properties对象:
第三种形式DriverManager.getConnection()方法需要一个数据库URL和一个Properties对象:
DriverManager.getConnection(Stringurl,Propertiesinfo);
Properties对象,保存一组关键字-值对。它被用来调用getConnection()方法时驱动程序属性传递给驱动程序。
为了使通过前面的例子中所做的相同的连接,使用下面的代码:
importjava.util.*; StringURL="jdbc:oracle:thin:@amrood:1521:EMP"; Propertiesinfo=newProperties(); info.put("user","username"); info.put("password","password"); Connectionconn=DriverManager.getConnection(URL,info);
关闭JDBC连接:
在JDBC程序的结束,它明确要求关闭所有的连接到数据库,以结束每个数据库会话。但是,如果忘了,Java垃圾收集器会关闭连接时,它会清除陈旧的对象。
依托垃圾收集,特别是在数据库编程,是非常差的编程习惯。应该总是在关闭与连接对象关联的close()方法连接的习惯。
为了确保连接被关闭,可以在代码中的finally块执行。finally块都会执行,不管是否发生或也不例外。
要关闭上面打开的连接,应该调用close()方法,如下所示:
conn.close();
显式地关闭连接DBMS节约资源。
创建JDBC应用程序:
有下列涉及构建JDBC应用程序的六个步骤:
- 导入数据包.需要包括含有需要进行数据库编程的JDBC类的包。大多数情况下,使用importjava.sql.* 就可以了.
- 注册JDBC驱动程序.需要初始化驱动程序,可以与数据库打开一个通信通道。
- 打开连接.需要使用DriverManager.getConnection()方法创建一个Connection对象,它代表与数据库的物理连接。
- 执行查询.需要使用类型声明的对象建立并提交一个SQL语句到数据库。
- 从结果集中提取数据.要求使用适当的关于ResultSet.getXXX()方法来检索结果集的数据。
- 清理环境.需要明确地关闭所有的数据库资源相对依靠JVM的垃圾收集。
示例代码:
这个范例的例子可以作为一个模板,在需要建立JDBC应用程序。
基于对环境和数据库安装在前面的章节中做此示例代码已写入。
复制下面的例子FirstExample.java,编译并运行,如下所示:
//STEP1.Importrequiredpackages importjava.sql.*; publicclassFirstExample{ //JDBCdrivernameanddatabaseURL staticfinalStringJDBC_DRIVER="com.mysql.jdbc.Driver"; staticfinalStringDB_URL="jdbc:mysql://localhost/EMP"; //Databasecredentials staticfinalStringUSER="username"; staticfinalStringPASS="password"; publicstaticvoidmain(String[]args){ Connectionconn=null; Statementstmt=null; try{ //STEP2:RegisterJDBCdriver Class.forName("com.mysql.jdbc.Driver"); //STEP3:Openaconnection System.out.println("Connectingtodatabase..."); conn=DriverManager.getConnection(DB_URL,USER,PASS); //STEP4:Executeaquery System.out.println("Creatingstatement..."); stmt=conn.createStatement(); Stringsql; sql="SELECTid,first,last,ageFROMEmployees"; ResultSetrs=stmt.executeQuery(sql); //STEP5:Extractdatafromresultset while(rs.next()){ //Retrievebycolumnname intid=rs.getInt("id"); intage=rs.getInt("age"); Stringfirst=rs.getString("first"); Stringlast=rs.getString("last"); //Displayvalues System.out.print("ID:"+id); System.out.print(",Age:"+age); System.out.print(",First:"+first); System.out.println(",Last:"+last); } //STEP6:Clean-upenvironment rs.close(); stmt.close(); conn.close(); }catch(SQLExceptionse){ //HandleerrorsforJDBC se.printStackTrace(); }catch(Exceptione){ //HandleerrorsforClass.forName e.printStackTrace(); }finally{ //finallyblockusedtocloseresources try{ if(stmt!=null) stmt.close(); }catch(SQLExceptionse2){ }//nothingwecando try{ if(conn!=null) conn.close(); }catch(SQLExceptionse){ se.printStackTrace(); }//endfinallytry }//endtry System.out.println("Goodbye!"); }//endmain }//endFirstExample
现在来编译上面的例子如下:
C:>javacFirstExample.java
当运行FirstExample,它会产生以下结果:
C:>javaFirstExample
Connectingtodatabase... Creatingstatement... ID:100,Age:18,First:Zara,Last:Ali ID:101,Age:25,First:Mahnaz,Last:Fatma ID:102,Age:30,First:Zaid,Last:Khan ID:103,Age:28,First:Sumit,Last:Mittal