學JSP的同學都要知道怎么連數據庫,網上的示例各有各的做法,弄得都不知道用誰的好。其實方法千變萬化,本質上就兩種:Jdbc-Odbc橋和Jdbc直連。
下面先以MySQL為例說說這兩種方式各是怎么連的?
方式一:Jdbc-Odbc橋
它所要用到的有JSP自帶的驅動 sun.jdbc.odbc.JdbcOdbcDriver 和 Windows系統中的 ODBC數據源。這兩種好在都不用下載,可以直接使用。原理是網頁向Jdbc驅動請求數據,Jdbc再向Odbc請求,最后Odbc向數據庫請求。Odbc我這里就不多說了,先用它建立一個MySQl的數據源,最好是系統數據源,過程中可能需要到 MySQL for ODBC 的驅動,如果沒有則先安裝,測試成功后留下待用。
接下來就編寫一個JSP網頁測試一下,代碼如下:
1 <%@ page contentType="text/html; charset=utf-8" language="java" import="java.sql.*" errorPage="" %>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <title>連接MySQL</title>
6 </head>
7 <body>
8 <%
9 //以下是關鍵部分
10 Connection con=null;
11 String DriverName="sun.jdbc.odbc.JdbcOdbcDriver";
12 String DBname="jdbc:odbc:你的數據源名";
13 String DBuser="root";
14 String DBcode="123";
15 //以上是關鍵部分
16 try
17 {
18 Class.forName(DriverName);
19 }
20 catch(Exception e)
21 {
22 out.print(e.toString());
23 }
24 try
25 {
26 con=DriverManager.getConnection(DBname,DBuser,DBcode);
27 }
28 catch(SQLException e)
29 {
30 out.print(e.toString());
31 }
32 %>
33 <p><b>JDBC連接ODBC數據庫測試結果</b></p>
34 <%
35 if(con!=null)
36 {
37 DatabaseMetaData dbmeta=con.getMetaData() ;
38 out.print("<br><b>數據庫產品:</b>"+dbmeta.getDatabaseProductName());
39 out.print("<br><b>數據庫版本:</b>"+dbmeta.getDatabaseProductVersion());
40 out.print("<br><b>用戶名:</b>"+dbmeta.getUserName());
41 out.print("<br><b>測試連接成功 ! </b>");
42 try{con.close();}
43 catch(Exception e){}
44 }
45 else
46 out.print("<br><b>連接失敗</b>");
47 %>
48 </body>
49 </html>
其中我注釋為關鍵代碼的部分是待會兒要替換的。MySQL的用戶名和密碼要根據你自己的實際情況加以更改。
如果測試成功,則會顯示數據庫的名稱 版本 登錄用戶 等信息。
把關鍵部分換成一下代碼,就是Oracle的了:
Connection con=null;
String DriverName="sun.jdbc.odbc.JdbcOdbcDriver";
String DBname="jdbc:odbc:你的數據源名";
String DBuser="scott";
String DBcode="tiger";
SQL Server也是一樣:
Connection con=null;
String DriverName="sun.jdbc.odbc.JdbcOdbcDriver";
String DBname="jdbc:odbc:你的數據源名";
String DBuser="sa";
String DBcode="123";
方式二:JDBC直連
這種方式需要用到數據庫公司為Java專門開發的 jar包,系統里是沒有的,得自己下,在文章的最后我會給出下載地址。
MySQL需要用的是 mysql-connector-java-5.1.18-bin.jar 把它拷貝到Tomcat根目錄下的 lib文件夾里就好了。
這也就意味着可以使用上述包里的 com.mysql.jdbc.Driver驅動了。以下是測試網頁代碼:
1 <%@ page contentType="text/html; charset=utf-8" language="java" import="java.sql.*"%>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <title>連接MySQL</title>
6 </head>
7 <body>
8 <%
9 //以下是關鍵部分
10 Connection con=null;
11 String DriverName="com.mysql.jdbc.Driver";
12 String DBname="jdbc:mysql://localhost:3306/要連接的數據庫名";
13 String DBuser="root";
14 String DBcode="123";
15 ////以上是關鍵部分
16 try
17 {
18 con=DriverManager.getConnection(DBname,DBuser,DBcode);
19 }
20 catch(SQLException e)
21 {
22 out.print(e.toString());
23 }
24 %>
25 <p><b>JDBC連接數據庫測試結果</b></p>
26 <%
27 if(con!=null)
28 {
29 DatabaseMetaData dbmeta=con.getMetaData() ;
30 out.print("<br><b>數據庫產品:</b>"+dbmeta.getDatabaseProductName());
31 out.print("<br><b>數據庫版本:</b>"+dbmeta.getDatabaseProductVersion());
32 out.print("<br><b>用戶名:</b>"+dbmeta.getUserName());
33 out.print("<br><b>測試連接成功 ! </b>");
34 try{con.close();}
35 catch(Exception e){}
36 }
37 else
38 out.print("<br><b>連接失敗</b>");
39 %>
40 </body>
41 </html>
測試的結果和方式一類似。
以下是Oracle的關鍵部分代碼:
Connection con=null;
String DriverName="oracle.jdbc.driver.OracleDriver";
String DBname="jdbc:oracle:thin:@計算機名:1521:數據庫實例名";
String DBuser="scott";
String DBcode="tiger";
以下是SQL Server的關鍵部分代碼:
Connection con=null;
String DriverName="com.microsoft.sqlserver.jdbc.SQLServerDriver";
String DBname="jdbc:sqlserver://localhost;DatabaseName=要連接的數據庫名";
String DBuser="sa";
String DBcode="123";
總結:
方式二的優點是整個過程中不需要用到ODBC,更加直接;缺點是需要為不同數據庫下載不同的JAR包。

