明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

用JDBC訪問一個數(shù)據(jù)庫

[摘要]發(fā)布者:flyfox 在這個練習(xí)里你將學(xué)習(xí)使用JDBC訪問數(shù)據(jù)庫和插入一個記錄到數(shù)據(jù)庫的基礎(chǔ)知識。 在這個練習(xí)里,你將寫RegistrationServlet類的register方法。這個類和你在Servlet1A練習(xí)里用的一樣。在這個練習(xí)里,你將使用數(shù)據(jù)庫的功能。這個練習(xí)將展示實現(xiàn)用戶需求的步驟...
發(fā)布者:flyfox

在這個練習(xí)里你將學(xué)習(xí)使用JDBC訪問數(shù)據(jù)庫和插入一個記錄到數(shù)據(jù)庫的基礎(chǔ)知識。

在這個練習(xí)里,你將寫RegistrationServlet類的register方法。這個類和你在Servlet1A練習(xí)里用的一樣。在這個練習(xí)里,你將使用數(shù)據(jù)庫的功能。這個練習(xí)將展示實現(xiàn)用戶需求的步驟。

第一部分:理解regsiter()方法在RegistrationServlet中的工作原理

在這個練習(xí)里,你將在com.ibm.waslab.JDBC包上工作。擴展RegistrationServlet類,理解register()。這個方法拋一個SQLException。完整的方法聲明是:

public synchronized void register(Properties formInput)

throws SQLException{



}

register()方法在servlet取得控制時從doPost()方法里被調(diào)用。register()方法實際上寫一個新的記錄到數(shù)據(jù)庫。我們將在第二部分寫register()方法。同時,我們需要確信一些設(shè)置步驟已經(jīng)完成。

1.打開init()方法,在super.init()的調(diào)用后面輸入以下的代碼:

//Load JDBC driver for DB2

try

{

Class.forName(JKToysDBInfo.gerDriver());

}

catch (ClassNotFoundException e)

{

erroLog(“JDBC Driver not found”+e);

}



保存init()方法。記住,在驅(qū)動器管理可以得到一個連接以前,一個正確的數(shù)據(jù)庫驅(qū)動器必須被servlet裝載。每一個servlet只在servlet的init()方法里作一次。這個方法并不真地建立一個連接,它只是允許連接被建立。



注意:在這個情況下,我們裝載DB2 app驅(qū)動器。這個驅(qū)動器是在數(shù)據(jù)庫裝在servlet將要運行的同一臺機器上時使用的。如果你在訪問另一臺機器上的數(shù)據(jù)庫,你要使用net驅(qū)動器:

COM.ibm.db2.jdbc.net.DB2Driver

當(dāng)用net驅(qū)動器得到一個連接,你需要在getConnection()里使用的URL里提供更多的信息。數(shù)據(jù)庫所在的機器名或URL,和DB2 Java Gateway偵聽的端口號。一個有效的URL參數(shù)看上去是這樣的:

jdbc:db2://servrid:8888/databasename

第二部分

1.現(xiàn)在,回去,重新打開register()方法。代碼的第一行創(chuàng)建一個數(shù)據(jù)庫連接:

Connection conn=DriverManager.getConnection(URL,USER,PASSWORD);

你用驅(qū)動器管理器的靜態(tài)方法getConnection(),把數(shù)據(jù)庫的URL,一個有效的用戶ID和口令傳遞給它。url,userid和password在類被裝載時從一個屬性文件里得到(看靜態(tài)變量聲明)。

2.現(xiàn)在到了有挑戰(zhàn)性的部分了。我們要作的第一件事是找到已經(jīng)被分配掉的最后一個客戶號碼,這樣我們可以分配給正在注冊的新客戶一個新的客戶號碼(比以前的最高的還要高)。我們要存儲這個新的客戶號碼在一個int變量名為nextId。為了做到這個,你會需要確信使用Statement類和ResultSet類。以下的SQL;

“SELECT MAX(CUSTNO) FORM”+DBOWNER+”.CUSTOMER”

將允許你獲得當(dāng)前最高的客戶號。試試自己寫這個代碼,基于課程筆記的例子。如果你需要幫助,看答案頁。

3.接著你將用一個prepared statement對象來把客戶屬性對象里的信息插入數(shù)據(jù)庫。輸入以下的行:

//Insert record in the database

PreparedStatement insertStatement=

conn.prepareStatement(“INSERT INTO”+DBOWNER+”.CUSTOMER(FNAME,LNAME,ADDR,CITY,STATE,AGE,ZIP,CUSTNO)”+”VALUES(?,?,?,?,?,?,?,?)”);

上面的行要求連接創(chuàng)建一個prepared statement對象叫insertStatement。SQL語句作為參數(shù)被傳遞。數(shù)據(jù)庫行的每一列的值用問號代表。每一個問號必須被一個正確類型的值代替。輸入以下行:

insertStatement.setString(1,formInput.getProperty(“FNAME”));

insertStatement.setString(2,formInput.getProperty(“LNAME”));

insertStatement.setString(3,formInput.getProperty(“ADDR”));

insertStatement.setString(4,formInput.getProperty(“CITY”));

insertStatement.setString(5,formInput.getProperty(“STATE”));

insertStatement.setString(6,formInput.getProperty(“AGE”));

insertStatement.setString(7,formInput.getProperty(“ZIP”));

insertStatement.setInt(8,nextId);

4.insertStatement執(zhí)行對數(shù)據(jù)庫的更新。輸入下面兩行:

insertStatement.executeUpdate();

如果有錯誤出現(xiàn)在創(chuàng)建連接時,語句或訪問數(shù)據(jù)庫,這個方法會拋出一個SQLException。

5.最后你需要存儲客戶號碼到formInput屬性對象。輸入下面行:

formInput.put(“CUSTNO”,new Integer(nextId).toString());

6.保存方法。應(yīng)該沒有錯誤。

7.接著你將需要為JKRegister servlet編輯WebSphere配置文件。(編輯”[x:]\IBMVJava\ide\project_resources\IBM WebSphere Test Environment\properties\server\servlet\servletservice\serrvlets.properties”.)

改變看上去這樣的行:

servlet.JKRegister.code=com.ibm.waslab.servlet1.RegistrationServlet

為這樣:

servlet.JKRegister,code=com.ibm.waslab.JDBC.RegistrationServlet

8.如果你的webserver在運行,關(guān)掉它。在VAJ,啟動SERunner。打開你的web瀏覽器,到JK Toys網(wǎng)站的注冊頁面。在表格里輸入注冊信息,按注冊按鈕。你的新的servlet將被調(diào)用。登錄進JKToys站點確信注冊已經(jīng)發(fā)生。你的新的客戶號碼應(yīng)該能在數(shù)據(jù)庫找到。



在這個練習(xí)你作了什么

在這個練習(xí),你編寫了Registration Servlet的register方法。這個方法用JDBC來創(chuàng)建一個新的客戶號碼,注冊一個新的客戶到數(shù)據(jù)庫,F(xiàn)在你有了在你的servlets里訪問數(shù)據(jù)庫的基本知識。



答案

以下的代碼創(chuàng)建一個SQL語句,執(zhí)行在前一頁里定義的SQL查詢。



//Get next customer number

Statement sqlStatement=conn.createStatement();

ResultSet result=sqlStatement.executeQuery(“SELECT MAX(CUSTNO) FROM”+DBOWNER+”.CUSTOMER”);

查詢的結(jié)果被放在ResultSet對象叫result里面。結(jié)果的集合包含一個游標(biāo),最初指向返回的第一行前面。為了得到查詢的值游標(biāo)必須用next()往前移動。用這個方法,游標(biāo)只能向前移動。下面幾行移動游標(biāo)到返回的值,增加1。

int nextId=0;

if(result.next()= =true)

{

nextId=result.getInt(1)+1;

}

if檢查確定是否有行被返回。如果沒有,結(jié)果為false。我們不處理錯誤的情況,但是它可以簡單地用把nextId設(shè)置為1來處理。我們還可以用ResultSet的方法getInt(String),列的名字為”CUSTNO”,但是因為我們知道只有一列會被返回,我們選擇用getInt(int)..