小編給大家分享一下JSP技術(shù)中表單數(shù)據(jù)存儲的通用方法有哪些,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
專注于為中小企業(yè)提供網(wǎng)站建設(shè)、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)堆龍德慶免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
J2EE(Java 2 Enterprise Edition)技術(shù)已廣泛應(yīng)用在Web應(yīng)用開發(fā)中,其中的JavaBean、Servlet技術(shù)為開發(fā)者提供了更為清晰的開發(fā)環(huán)境,使用JSP技術(shù)表現(xiàn)頁面,使用Servlet技術(shù)完成大量的業(yè)務(wù)處理,使用Bean來存儲數(shù)據(jù)及一些業(yè)務(wù)處理。在WEB應(yīng)用中,業(yè)務(wù)數(shù)據(jù)存儲到數(shù)據(jù)庫中的處理工作經(jīng)常很繁重,其中一種主要的形式就是表單數(shù)據(jù)存儲到數(shù)據(jù)庫,整個應(yīng)用處理過程牽涉到大量的這種數(shù)據(jù)存儲操作,對每個表單都要單獨編寫相應(yīng)的數(shù)據(jù)存儲程序,花費了開發(fā)人員大量的時間和精力。采用什么方法來減輕表單數(shù)據(jù)存儲的開發(fā)工作量是值得研究的問題。
兩種常見的表單數(shù)據(jù)存儲處理方法
1、對每一表單都編寫相應(yīng)的程序代碼
在JSP頁面或JavaBean或Servlet中,使用request. getparameter()函數(shù)逐一提取表單提交的數(shù)據(jù),或編寫相應(yīng)的JavaBean,使用setProperty方法將數(shù)據(jù)自動取到 JavaBean中,然后生成SQL語句(insert,update,delete),***執(zhí)行executeupdate()函數(shù)完成數(shù)據(jù)表存儲。
2、對每一數(shù)據(jù)表自動生成一個JavaBean程序代碼
數(shù)據(jù)庫系統(tǒng)必須支持用戶能夠讀取表結(jié)構(gòu),并識別關(guān)鍵字段。利用面向?qū)ο罂焖匍_發(fā)工具,如PowerBuilder、Delphi等,自行開發(fā)一個Java代碼自動生成程序。在該程序中讀取數(shù)據(jù)庫表的結(jié)構(gòu):字段名、數(shù)據(jù)類型、數(shù)據(jù)長度,自動生成一個JavaBean代碼。在該代碼中定義與表中字段對應(yīng)的同名變量,建立所有變量的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="*" />
然后調(diào)用table1_bean中insert、update、delete函數(shù)完成數(shù)據(jù)表存儲,并返回執(zhí)行結(jié)果。如:
<%boolean success =table.insert(); %>
***種方法簡單直觀,但對每一表單都需要編寫相應(yīng)的數(shù)據(jù)處理程序。對稍微大一點的應(yīng)用,表單數(shù)量可能很多,開發(fā)工作量很大,開發(fā)工作效率低。表結(jié)構(gòu)變動如增加、減少字段時,需修改相應(yīng)的數(shù)據(jù)處理程序。
第二種方法相對***種簡便得多,每一數(shù)據(jù)表的數(shù)據(jù)處理由對應(yīng)的JavaBean實現(xiàn),JavaBean自動生成,不需編寫,表結(jié)構(gòu)變動時只需重新生成新的JavaBean,經(jīng)Java編譯后覆蓋原Java類即可。但該方法需要開發(fā) JavaBean自動生成程序,表結(jié)構(gòu)變動時JavaBean需要重新生成和編譯。
介紹一種簡便通用的方法實現(xiàn)表單數(shù)據(jù)存儲
在WEB應(yīng)用開發(fā)中,很多表單在經(jīng)過前臺瀏覽器端簡單的數(shù)據(jù)校驗后,提交后臺服務(wù)器,服務(wù)器對數(shù)據(jù)不用作任何處理直接將數(shù)據(jù)存儲到一個數(shù)據(jù)表中。對這種情況,我們可以只編寫一個程序,對這些表單統(tǒng)一處理,將數(shù)據(jù)存儲到相應(yīng)的一個數(shù)據(jù)表中。該方法同樣要求數(shù)據(jù)庫系統(tǒng)支持表結(jié)構(gòu)讀取和關(guān)鍵字段識別。我們采用JSP技術(shù)編寫該程序,程序文件取名為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值應(yīng)與數(shù)據(jù)表的字段名相同,DBdataStore.jsp中逐一提取表單提交的對應(yīng)字段名的數(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) 建立表的關(guān)鍵列視圖
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';
看完了這篇文章,相信你對“JSP技術(shù)中表單數(shù)據(jù)存儲的通用方法有哪些”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)頁名稱:JSP技術(shù)中表單數(shù)據(jù)存儲的通用方法有哪些
文章轉(zhuǎn)載:http://www.chinadenli.net/article10/gcipdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、ChatGPT、關(guān)鍵詞優(yōu)化、搜索引擎優(yōu)化、網(wǎng)站維護、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)