本文以Oracle資料庫為例,介紹了在採用JSP技術開發WEB應用時一種簡便通用的表單數據存儲處理方法,以減輕開發工作量,同時提供了主要的程序代碼.
引言
J2EE(Java 2 Enterprise Edition)技術已廣泛應用在Web應用開發中,其中的JavaBean、Servlet技術為開發者提供了更為清晰的開發環境,使用JSP技術表現頁面,使用Servlet技術完成大量的業務處理,使用Bean來存儲數據及一些業務處理.在WEB應用中,業務數據存儲到資料庫中的處理工作經常很繁重,其中一種主要的形式就是表單數據存儲到資料庫,整個應用處理過程牽涉到大量的這種數據存儲操作,對每個表單都要單獨編寫相應的數據存儲程序,花費了開發人員大量的時間和精力.採用什麼方法來減輕表單數據存儲的開發工作量是值得研究的問題.
兩種常見的表單數據存儲處理方法
1、對每一表單都編寫相應的程序代碼
在JSP頁面或JavaBean或Servlet中,使用request. getparameter()函數逐一提取表單提交的數據,或編寫相應的JavaBean,使用setProperty方法將數據自動取到JavaBean中,然後生成SQL語句(insert,update,delete),最后執行executeupdate()函數完成數據表存儲.
2、對每一數據表自動生成一個JavaBean程序代碼
資料庫系統必須支持用戶能夠讀取表結構,並識別關鍵欄位.利用面向對象快速開發工具,如PowerBuilder、Delphi等,自行開發一個java代碼自動生成程序.在該程序中讀取資料庫表的結構:欄位名、數據類型、數據長度,自動生成一個JavaBean代碼.在該代碼中定義與表中欄位對應的同名變數,建立所有變數的setValue和getValue方法,建立insert、update、delete函數分別處理insert、update、delete的SQL語句生成和執行.
在表單提交的數據處理頁面中,編寫如下代碼,將表單數據存儲到JavaBean中:
<jsp:useBean id="table" class="table1_bean" />
<jsp:setProperty name="table" property="*" />
(註:table1_bean為上述自動生成的對應某一個表的JavaBean)
然後調用table1_bean中insert、update、delete函數完成數據表存儲,並返回執行結果.如:
<%boolean success =table.insert(); %>
第一種方法簡單直觀,但對每一表單都需要編寫相應的數據處理程序.對稍微大一點的應用,表單數量可能很多,開發工作量很大,開發工作效率低.表結構變動如增加、減少欄位時,需修改相應的數據處理程序.
第二種方法相對第一種簡便得多,每一數據表的數據處理由對應的JavaBean實現,JavaBean自動生成,不需編寫,表結構變動時只需重新生成新的JavaBean,經java編譯后覆蓋原java類即可.但該方法需要開發JavaBean自動生成程序,表結構變動時JavaBean需要重新生成和編譯.
介紹一種簡便通用的方法實現表單數據存儲
在WEB應用開發中,很多表單在經過前台瀏覽器端簡單的數據校驗后,提交後台伺服器,伺服器對數據不用作任何處理直接將數據存儲到一個數據表中.對這種情況,我們可以只編寫一個程序,對這些表單統一處理,將數據存儲到相應的一個數據表中.該方法同樣要求資料庫系統支持表結構讀取和關鍵欄位識別.我們採用JSP技術編寫該程序,程序文件取名為DbdataStore.jsp.
1、調用格式
在網頁中表單的Action調用方法如下:
<Form Name=Frm1 Method=Post Action="DBdataStore.jsp? tablename=table1&OperType=…">
table1為數據將要存儲的資料庫表的表名,OperType操作類型分為三種:insert,update,delete.
表單中的<input type=text name=…>,<textarea name=…><select name=…>等中的name值應與數據表的欄位名相同,DBdataStore.jsp中逐一提取表單提交的對應欄位名的數據值,若表單中未定義輸入,得到的值為空值,則對該欄位不作處理.
2、以oracle為例的視圖定義
1) 建立表各列數據類型視圖
CREATE OR REPLACE VIEW v_dbstru AS SELECT table_name,column_name,data_type,data_length,data_precision,data_scale,column_id
FROM all_tab_columns WHERE owner='user1';//user1為數據表的屬主.
2) 建立表的關鍵列視圖
CREATE OR REPLACE VIEW v_pkey_column AS
SELECT b.table_name,b.column_name,b.position
FROM all_constraints a,all_cons_columns b
WHERE a.owner=b.owner AND a.constraint_name=b.constraint_name AND a.owner='user1' AND a.constraint_type='P';
3、主要程序代碼
1) 程序初始化
String tablename=request.getParameter("tablename");//提取表名
String OperType=request.getParameter("OperType");//提取操作類型
String sFieldValue="";//存放表單提交的欄位數據值
String fieldname="",Datatype="" //存放欄位名,欄位數據類型
int iFieldvalue=0;
String updateSql="",whereSql=" where ",insSql1="",insSql2="",opSql="",strSql ="";
ResultSet rs1=null,rs2=null;
insSql1="insert into " tablename " (";
insSql2="values(";
2)生成sql語句關鍵欄位部分
生成insert語句關鍵欄位部分,如:insert into table1(id 和 values(100));
只使用關鍵欄位生成update,delete語句where部分,如:where id=100;
在操作類型為update時,網頁form表單中不對關鍵欄位的數據進行修改.
|
3)非關鍵欄位部分sql語句生成
update語句,如:update table1 set column1=value1,… where id=100
insert語句,如:insert into table1(id,column1,…)values(100,value1,…)
|
4)生成完整的sql語句並執行
|
4、特點
該方法對所有這種直接存儲的表單都統一使用本程序,具有通用性,不必對每個表單或每個數據表獨立開發相應程序,開發工作量非常少,調用也非常簡便.同時,在表結構變動時,不用修改DBdataStore.jsp程序.本程序也可改寫為Servelet,調用格式為<Form Name=Frm1 Method=Post Action="DBdataStoreServelet?tablename=table1&OperType=…">.
結束語
在Web應用中,如果表單數據在提交后,還需要伺服器後台作進一步的數據校驗或處理,則需要採用第二種方法.但很多情況是用戶在表單中輸入或修改數據,在前台瀏覽器端使用javascript對數據進行簡單校驗或處理,然後提交,在後台伺服器端不作任何處理,直接將表單提交的數據存儲到資料庫的一個表中.這時候採用第三種方法非常簡便,可以大大減輕開發人員的工作量.
[火星人 ] JSP中表單數據存儲的通用方法已經有790次圍觀