對於JSP中表單資料儲存的一種通用方法
阿新 • • 發佈:2019-01-31
引言
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中:
然後呼叫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) 建立表各列資料型別檢視
2) 建立表的關鍵列檢視
3、主要程式程式碼
1) 程式初始化
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對資料進行簡單校驗或處理,然後提交,在後臺伺服器端不作任何處理,直接將表單提交的資料儲存到資料庫的一個表中。這時候採用第三種方法非常簡便,可以大大減輕開發人員的工作量。
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中:
然後呼叫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) 建立表各列資料型別檢視
2) 建立表的關鍵列檢視
3、主要程式程式碼
1) 程式初始化
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對資料進行簡單校驗或處理,然後提交,在後臺伺服器端不作任何處理,直接將表單提交的資料儲存到資料庫的一個表中。這時候採用第三種方法非常簡便,可以大大減輕開發人員的工作量。