js|mysql|oracle|window|資料|資料庫 Jsp 環境目前最流行的是 Tomcat5.0。Tomcat5.0 自己包含一個 Web 服務器,如果是測試,就沒必要把 Tomcat 與 IIS 或 Apache 整合起來。在 Tomcat 內建的 Web 服務器下可以進行 Jsp 測試。
安裝 Tomcat5.0 前需要安裝 JDK(如果是 Windows server 2003 就必須安裝 JDK,因為 Windows server 2003 是不帶 JVM 的-Windows server 2003 發行時 MS 和 SUN 剛好鬧彆扭呢)。安裝完後,要設定幾個環境變數:
JAVA_HOME = E:\j2sdk1.4.2_04
CLASSPATH = E:\j2sdk1.4.2_04\lib;E:\j2sdk1.4.2_04\lib\tools.jar
Path 中加 .;E:\j2sdk1.4.2_04\bin;
CATALINA_HOME = E:\Tomcat 5.0
TOMCAT_HOME = E:\Tomcat 5.0
解釋如下:我的 JDK版本是 1.4.2,安裝在 E:\j2sdk1.4.2_04 檔案夾下。
環境變數 JAVA_HOME 和 CATALINA_HOME 是一定要加的(至少參考資料都是這麼說的)。CLASSPATH 也說要加,但是我沒加似乎也沒什麼影響。Path 中加 “.;E:\j2sdk1.4.2_04\bin;”也一樣,我不加 jsp 也能運行起來,但是在 DOS 視窗下手工編譯 .java 類到 .class 檔案有影響,因為找不到 javac.exe 編譯命令檔案。至於 path 中加的那個點“.”,我原來在 resin 下是需要的,在 Tomcat 下還沒確定它是不是必須的。
大家還發現 CATALINA_HOME 和 TOMCAT_HOME 的值是一樣的,我估計 TOMCAT_HOME 是 Tomcat 的舊版本使用的,現在用的都是 CATALINA_HOME。不過這2個好象並不是不相容的,都加上,或者加其中任意一個,Jsp 都不手影響。不過我建議用一個 CATALINA_HOME 就算了。
Tomcat5.0 設定虛擬路徑比較方便了,因為可以在 Web 環境下管理。http://[url]:8080/admin 可以進入管理介面(管理員admin密碼在 Tomcat 安裝過程中可以設定),在 Tomcat Server-Service (Catalina)-Host (localhost)下可以添加 Context,類似於 IIS
裡的虛擬路徑:Document Base 指的是從實際 E:\Tomcat 5.0\webapps\ROOT 為起點的檔案路徑,Path 指的是從虛擬“/”開始的虛擬路徑名,如“/mytest”。這裡 Tomcat 好象設計的有點不完善,只要加了新的 Context,儲存,再點“Commit Changes”按鈕,再點Context 去看時,介面就會退到登入介面,但是有時頁面就出錯了,必須再次手工進入http://[url]:8080/admin。加了 Context,Apache Tomcat 服務必須“關閉/啟動”一下(在Windows管理主控台的服務裡)。有資料說在 http://localhost:8088/manager 管理介面下可以 Start 和 Stop 來重新啟動對應的 Context,但是我 Stop 後就是 Start 不起來。點了一下 Undeploy,就把 Context 刪除了,注意:把 Context 對應的物理檔案夾也給刪除了!!就是說你做了個應用,移到這裡,如果不小心,就給刪了-比病毒還厲害。小心啊!!
下來我說一下 Jsp 串連 mySQL 的問題。如果用 Jsp 去串連 Access,我感覺就是把裙子穿在男人身上。Access 和 ASP 才是天造地設的一對。Jsp 串連 mySQL 或者 Oracle 才算合情合理。原因我認為是:用 Jsp 做開發,其優勢就是跨 OS 平台,如果用 Jsp + Access 組合,跨平台的優勢就沒有了。ASP 和 Access 已經工作的很好了,也簡單,你何必要彆扭的去用 Jsp 開發?當然,如果您對 Jsp 非常熟悉(或者對 Asp 非常不熟悉),或者非常喜歡 Jsp(或者非常不喜歡 Asp),或者您有大量的資料積累在 Access 裡,您要用 Jsp+Access 在技術上也不是不行的。
mySQL 的安裝非常簡單,基本安裝完畢都能正常使用,建立資料庫,設定使用者,都可以在 mySQL 的環境下完成。就是對用慣了 GUI 介面的人,感覺不順手。網上能下載到一些 mySQL 的圖形化使用者介面的管理工具,但好象不是免費的。
用 Jsp 串連 mySQL 資料庫,從表裡取資料,寫一段代碼測試一下:
程式碼1:
<!--首先匯入一些必要的packages-->
<%@ page import="java.io.*"%>
<%@ page import="java.util.*"%>
<!--告訴編譯器使用SQL包-->
<%@ page import="java.sql.*"%>
<!--設定中文輸出-->
<%@ page contentType="text/html; charset=GB2312" %>
<html>
<head>
<title>mySQL test</title>
</head>
<body>
<%
Connection con;
Statement stmt;
ResultSet rs;
//載入驅動程式,下面的代碼為載入MySQL驅動程式
Class.forName("com.mysql.jdbc.Driver");
//註冊MySQL驅動程式
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//用適當的驅動程式串連到資料庫
//String dbUrl = "jdbc:mysql://localhost:3306/mysql?useUnicode=true&characterEncoding=GB2312";
//String dbUser = "root"; //使用者名稱
//String dbPwd = "abcd1001"; //密碼
//建立資料庫連接
//con = java.sql.DriverManager.getConnection(dbUrl, dbUser, dbPwd);
String dbUrl ="jdbc:mysql://localhost:3306/mysql?user=root&password=abcd1001&useUnicode=true&characterEncoding=gb2312";
con = DriverManager.getConnection(dbUrl);
//建立一個JDBC聲明
stmt = con.createStatement();
//增加新記錄
//stmt.executeUpdate("INSERT INTO books (id,name,title,price) VALUES ('999','Tom','Tomcat Bible',44.5)");
//查詢記錄
rs = stmt.executeQuery("select * from user");
//輸出查詢結果
out.println("<table border=1 width=400>");
while (rs.next())
{
String col1 = rs.getString(1);
String col2 = rs.getString(2);
String col3 = rs.getString(3);
String col4 = rs.getString(4);
//列印所顯示的資料
out.println("<tr><td>"+col1+"</td><td>"+col2+"</td><td>"+col3+"</td><td>"+col4+"</td></tr>");
}
out.println("</table>");
//關閉資料庫連結
rs.close();
stmt.close();
con.close();
%>
</body>
</html>
程式碼2:
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.sql.*"%>
<html>
<body>
<%
Class.forName("org.gjt.mm.mysql.Driver").newInstance();
String url ="jdbc:mysql://localhost/chclyb?user=root&password=abcd1001&useUnicode=true&characterEncoding=8859_1";
//testDB為你的資料庫名
Connection conn= DriverManager.getConnection(url);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
String sql="select * from test";
ResultSet rs=stmt.executeQuery(sql);
while(rs.next()) {%>
第一個欄位內容為:<%=rs.getString(1)%>
第二個欄位內容為:<%=rs.getString(2)%><br>
<%}%>
<%out.print("資料庫操作成功,恭喜你");%>
<%rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
我的以上 2 段代碼都能工作。注意以上2段代碼的 Class.forName(…) 部分的不同:
Class.forName("com.mysql.jdbc.Driver"); //在程式碼1中
Class.forName("org.gjt.mm.mysql.Driver").newInstance(); //在程式碼2中
程式碼 2 中的代碼是為了相容 mySQL 的老版本而保留的,現在都用 Class.forName("com.mysql.jdbc.Driver"); 驅動了。
以上的代碼拷貝到 Tomcat 的虛擬路徑下能成功執行嗎?恐怕不行。因為還有個重要的事情沒有做:需要給 Tomcat5.0 安裝 mySQL 的 JDBC 驅動程式!這個問題,網上的大多數文章都沒講,給貼一段串連 mySQL 的代碼,就讓我們去串連資料庫了,連不上的!
mySQL 的驅動需要從網上下載,下載完畢,拷貝到 E:\Tomcat 5.0\common\lib 路徑下(我下載下來檔案名稱是mysql-connector-java-3.2.0-alpha-bin.jar),把 Tomcat 服務來個Stop/start 安裝就結束了。檔案名稱可以改的,不影響使用,因為這是個壓縮包,Tomcat 能自動認識到包裡的內容,並把有關類註冊進來。前面說的 Class.forName(…) 部分的不同可以在包裡找到答案,因為包裡正有 com/mysql/jdbc/Driver 和 org/gjt/mm/mysql/Driver 2 個路徑,下面放的類檔案是一樣的。
用 Jsp 串連 Oracle 資料庫測試,就好說了,但是同樣必須在 E:\Tomcat 5.0\common\lib 路徑下拷貝和註冊 Oracle 的 JDBC 驅動,這個驅動檔案沒必要在網上四處打聽,顯得很菜的樣子(我當初就是這樣!),這個檔案在 Oracle 的 E:\oracle\ora90\jdbc\lib 路徑下,檔案名稱是 classes12.jar。我的範例程式碼如下:
程式碼3:
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.sql.*"%>
<html>
<body>
<%
Class.forName("oracle.jdbc.driver.OracleDriver"); //.newInstance();
String url="jdbc:oracle:thin:@10.0.1.1:1521:mydb"; //mydb為資料庫的SID,10.0.1.1 為 資料庫伺服器 IP
String user="system";
String password="abcd1001";
Connection conn= DriverManager.getConnection(url, user, password);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
String sql="select * from test"; //test 是表名,要先建立這個表,再送幾條記錄
ResultSet rs=stmt.executeQuery(sql);
while(rs.next())
{
%>
第一個欄位內容為:<%=rs.getString(1)%>
第二個欄位內容為:<%=rs.getString(2)%> <br>
<%
}
out.print("資料庫操作成功,恭喜。");
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
關於 Oracle 資料庫:我安裝的是 Oracle9i 企業版(Windows server 2003 下),安裝完畢後,Oracle 將佔用 80 連接埠運行內建的 Apache1.3 Web伺服器,還佔用 8080 連接埠運行 TNSLSNR 服務(TNSLSNR.EXE檔案在 X:\oracle\ora90\BIN 下),提供一些 log 及文檔。所以建議安裝 Oracle 的機器就不要安裝 IIS 了,如果 IIS 先啟動起來,Oracle 的 http 服務就不能啟動了。也不能佔用 8080 連接埠。問題是如果還安裝 Tomcat,Tomcat 預設正好用的是 8080 連接埠,所以安裝 Tomcat 時最好把連接埠設成別的值,如 8088。
Oracle 裡建立表,必須先建立資料表空間,還可以加一個資料檔案(也可以不加,因為建立資料表空間時預設已經建了一個資料檔案。以後可以視需要再添加)。再建立一個使用者(以後的“方案”名和使用者名稱一樣)。建立表時,要選擇資料表空間和方案名,最好把表建立在對應的方案下,把他們對應起來,以後好管理。如果把表建立在別的“方案”下,用 SQL*plus 語句訪問時要用 [方案].[表名]的格式。
稀稀拉拉說了這麼多,是我的一些筆記類的東西。有些東西真的不太懂的,因為剛剛接觸了一些非 Microsoft 的東西。希望高手指出我說的和理解不對的地方。新手也不要完全接收我的東西,多想一下,看在您的環境下,我說的能不能調試成功。