多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 數據庫 > Oracle > JSP+Oracle簡便通用的表單數據存儲處理方法

JSP+Oracle簡便通用的表單數據存儲處理方法

來源:程序員人生   發布時間:2014-06-14 12:25:09 閱讀次數:3883次
摘 要

本文以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';
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 日本爱爱视频网站 | 久久综合九色综合欧洲 | 亚洲在线一区二区三区 | 男女全黄一级带免费 | 久久精品18 | 亚洲不卡一区二区三区 | 国产91久久久久久久免费 | aⅴ在线免费观看 | 日本在线观看中文字幕 | 99精品国产高清一区二区 | 精品久久亚洲一级α | 亚洲精品欧美日韩 | 日本www在线播放 | 国产成人精品免费视频网页大全 | 亚洲 春色 古典 小说 自拍 | 国产人成久久久精品 | 毛片亚洲毛片亚洲毛片 | 欧美干色 | 欧美日韩亚洲国产精品一区二区 | 国产成人啪精品午夜在线播放 | 噜噜噜久久 | 自拍自偷| 性鸥美 | 久久久高清日本道免费观看 | www免费视频 | 亚洲片在线观看 | 国产亚洲精品久久久久久 | 人成免费a级毛片 | 久久久影院亚洲精品 | 成年人小视频在线观看 | 亚洲一区免费看 | 日韩久久一区二区三区 | 精品欧美一区二区三区 | 欧美一区二区三区高清不卡tv | 最近中文字幕国语免费 | 狂野欧美激情性xxxx | 欧美a毛片 | 99久久久国产精品免费牛牛四川 | 亚洲成人第一 | 精品视频中文字幕 | 亚洲欧美日韩国产综合高清 |