摘 要 本文以Oracle數(shù)據(jù)庫為例,介紹了在采用jsp技術開發(fā)WEB應用時一種簡便通用的表單數(shù)據(jù)存儲處理方法,以減輕開發(fā)工作量,同時提供了主要的程序代碼。 引言 J2EE(java 2 EnterPRise Edition)技術已廣泛應用在Web應用開發(fā)中,其中的JavaBean、Servlet技術為開發(fā)者提供了更為清晰的開發(fā)環(huán)境,使用JSP技術表現(xiàn)頁面,使用Servlet技術完成大量的業(yè)務處理,使用Bean來存儲數(shù)據(jù)及一些業(yè)務處理。在WEB應用中,業(yè)務數(shù)據(jù)存儲到數(shù)據(jù)庫中的處理工作經(jīng)常很繁重,其中一種主要的形式就是表單數(shù)據(jù)存儲到數(shù)據(jù)庫,整個應用處理過程牽涉到大量的這種數(shù)據(jù)存儲操作,對每個表單都要單獨編寫相應的數(shù)據(jù)存儲程序,花費了開發(fā)人員大量的時間和精力。采用什么方法來減輕表單數(shù)據(jù)存儲的開發(fā)工作量是值得研究的問題。 兩種常見的表單數(shù)據(jù)存儲處理方法 1、對每一表單都編寫相應的程序代碼 在JSP頁面或JavaBean或Servlet中,使用request. getparameter()函數(shù)逐一提取表單提交的數(shù)據(jù),或編寫相應的JavaBean,使用setProperty方法將數(shù)據(jù)自動取到JavaBean中,然后生成SQL語句(insert,update,delete),最后執(zhí)行executeupdate()函數(shù)完成數(shù)據(jù)表存儲。 2、對每一數(shù)據(jù)表自動生成一個JavaBean程序代碼 數(shù)據(jù)庫系統(tǒng)必須支持用戶能夠讀取表結構,并識別關鍵字段。利用面向?qū)ο罂焖匍_發(fā)工具,如PowerBuilder、Delphi等,自行開發(fā)一個java代碼自動生成程序。在該程序中讀取數(shù)據(jù)庫表的結構:字段名、數(shù)據(jù)類型、數(shù)據(jù)長度,自動生成一個JavaBean代碼。在該代碼中定義與表中字段對應的同名變量,建立所有變量的setValue和getValue方法,建立insert、update、delete函數(shù)分別處理insert、update、delete的SQL語句生成和執(zhí)行。 在表單提交的數(shù)據(jù)處理頁面中,編寫如下代碼,將表單數(shù)據(jù)存儲到JavaBean中: <jsp:useBean id="table" class="table1_bean" /> <jsp:setProperty name="table" property="*" /> (注:table1_bean為上述自動生成的對應某一個表的JavaBean) 然后調(diào)用table1_bean中insert、update、delete函數(shù)完成數(shù)據(jù)表存儲,并返回執(zhí)行結果。如: <%boolean success =table.insert(); %> 第一種方法簡單直觀,但對每一表單都需要編寫相應的數(shù)據(jù)處理程序。對稍微大一點的應用,表單數(shù)量可能很多,開發(fā)工作量很大,開發(fā)工作效率低。表結構變動如增加、減少字段時,需修改相應的數(shù)據(jù)處理程序。 第二種方法相對第一種簡便得多,每一數(shù)據(jù)表的數(shù)據(jù)處理由對應的JavaBean實現(xiàn),JavaBean自動生成,不需編寫,表結構變動時只需重新生成新的JavaBean,經(jīng)java編譯后覆蓋原java類即可。但該方法需要開發(fā)JavaBean自動生成程序,表結構變動時JavaBean需要重新生成和編譯。 介紹一種簡便通用的方法實現(xiàn)表單數(shù)據(jù)存儲 在WEB應用開發(fā)中,很多表單在經(jīng)過前臺瀏覽器端簡單的數(shù)據(jù)校驗后,提交后臺服務器,服務器對數(shù)據(jù)不用作任何處理直接將數(shù)據(jù)存儲到一個數(shù)據(jù)表中。對這種情況,我們可以只編寫一個程序,對這些表單統(tǒng)一處理,將數(shù)據(jù)存儲到相應的一個數(shù)據(jù)表中。該方法同樣要求數(shù)據(jù)庫系統(tǒng)支持表結構讀取和關鍵字段識別。我們采用JSP技術編寫該程序,程序文件取名為DbdataStore.jsp。 1、調(diào)用格式 在網(wǎng)頁中表單的Action調(diào)用方法如下: <Form Name=Frm1 Method=Post Action="DBdataStore.jsp? tablename=table1&OperType=…"> table1為數(shù)據(jù)將要存儲的數(shù)據(jù)庫表的表名,OperType操作類型分為三種:insert,update,delete。 表單中的<input type=text name=…>,<textarea name=…><select name=…>等中的name值應與數(shù)據(jù)表的字段名相同,DBdataStore.jsp中逐一提取表單提交的對應字段名的數(shù)據(jù)值,若表單中未定義輸入,得到的值為空值,則對該字段不作處理。 2、以oracle為例的視圖定義 1) 建立表各列數(shù)據(jù)類型視圖 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為數(shù)據(jù)表的屬主。 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="";//存放表單提交的字段數(shù)據(jù)值
String fieldname="",Datatype="" //存放字段名,字段數(shù)據(jù)類型
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時,網(wǎng)頁form表單中不對關鍵字段的數(shù)據(jù)進行修改。
|
3)非關鍵字段部分sql語句生成
update語句,如:update table1 set column1=value1,… where id=100
insert語句,如:insert into table1(id,column1,…)values(100,value1,…)
|
4)生成完整的sql語句并執(zhí)行
|
4、特點
該方法對所有這種直接存儲的表單都統(tǒng)一使用本程序,具有通用性,不必對每個表單或每個數(shù)據(jù)表獨立開發(fā)相應程序,開發(fā)工作量非常少,調(diào)用也非常簡便。同時,在表結構變動時,不用修改DBdataStore.jsp程序。本程序也可改寫為Servelet,調(diào)用格式為<Form Name=Frm1 Method=Post Action="DBdataStoreServelet?tablename=table1&OperType=…">。
結束語
在Web應用中,如果表單數(shù)據(jù)在提交后,還需要服務器后臺作進一步的數(shù)據(jù)校驗或處理,則需要采用第二種方法。但很多情況是用戶在表單中輸入或修改數(shù)據(jù),在前臺瀏覽器端使用javascript對數(shù)據(jù)進行簡單校驗或處理,然后提交,在后臺服務器端不作任何處理,直接將表單提交的數(shù)據(jù)存儲到數(shù)據(jù)庫的一個表中。這時候采用第三種方法非常簡便,可以大大減輕開發(fā)人員的工作量。
|
新聞熱點
疑難解答
圖片精選