新手看招:JSP中表單數據存儲的通用方法

摘 要

本文以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表單中不對關鍵字段的數據進行修改。

rs1=Stmt.executeQuery("SELECT column_name FROM v_pkey_column WHERE table_name='"+tablename+"'");

//取關鍵字段字段名

while(rs1.next()){

fieldname=rs1.getString("column_name");

rs2=Stmt.executeQuery("SELECT data_type FROM v_dbstru WHERE table_name='"+tablename+"'

AND column_name='"+fieldname+"'");//取關鍵字段數據類型

if(rs2.next()){

Datatype=rs2.getString("data_type");

sFieldValue=request.getParameter(fieldname.toLowerCase());

//生成insert語句關鍵字段部分

if(OperType.equals("insert")){

insSql1+=fieldname+",";

if((sFieldValue==null) ){

//表單未提交關鍵字段數據值時,本文只按數字型處理,數據值按下一流水號計算。

rs2= Stmt. executeQuery("SELECT max("+fieldname+")+1 FROM "+tablename);

rs2. next();iFieldvalue=rs2.getInt(1);insSql2+=Integer.toString(iFieldvalue)+",";

}else if(Datatype.equals("DATE")){

insSql2+= "To_Date('" + sFieldValue + "','YYYY-MM-DD'),";

}else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){

insSql2+="'" + sFieldValue+"',";}

else /*NUMBER,FLOAT */ insSql2+=sFieldValue+",";}

//生成update,delete語句where部分:where fieldname=... AND

if(OperType.equals("update") || OperType.equals("delete")){

if(Datatype.equals("DATE")){

whereSql+=fieldname+"=To_Date('" + sFieldValue + "','YYYY-MM-DD') AND ";

}else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){

whereSql+=fieldname+"='" + sFieldValue+"' AND ";}

else /*NUMBER,FLOAT */ whereSql+=fieldname+"="+ sFieldValue+" AND ";}

}

}

whereSql=whereSql.substring(0,whereSql.length()-4);

3)非關鍵字段部分sql語句生成

update語句,如:update table1 set column1=value1,… where id=100

insert語句,如:insert into table1(id,column1,…)values(100,value1,…)

updateSql="update "+tablename+" set ";

strSql="SELECT column_name,data_type,data_length,data_precision,data_scale FROM

v_dbstru a "+"where table_name='"+tablename+"'

AND a.column_name not in (SELECT

b.column_name FROM v_pkey_column b where b.table_name=a.table_name)";

rs1=Stmt.executeQuery(strSql);//取非關鍵字段字段名和數據類型

while(rs1.next()){

fieldname=rs1.getString("column_name");Datatype=rs1.getString("data_type");

sFieldValue=request.getParameter(fieldname.toLowerCase());

//若表單未提交該字段的值,則忽略該字段的處理

if((sFieldValue!=null)){

//生成insert語句=insSql1+insSql2 即insert into tablename(… 和 values(…

if(OperType.equals("insert")){ insSql1+=fieldname+",";

if(Datatype.equals("DATE")){

insSql2+= "To_Date('" + sFieldValue + "','YYYY-MM-DD'),";

} else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){

insSql2+="'" + sFieldValue+"',";}else /*NUMBER,FLOAT*/ insSql2+= sFieldValue+",";}

//生成update語句=updateSql+whereSql 即update tablename set ... where

fieldname=... if(OperType.equals("update")){

if(Datatype.equals("DATE")){

updateSql+=fieldname+"=To_Date('" + sFieldValue + "','YYYY-MM-DD'),";

}else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){

updateSql+=fieldname+"='" + sFieldValue,1}+"',";}else /*NUMBER,FLOAT*/

updateSql+=fieldname+"="+sFieldValue+",";} ))

rs1.close();

4)生成完整的sql語句並執行

if(OperType.equals("insert"))

opSql=insSql1.substring(0,insSql1.length()-1)+")"+insSql2.substring(0,insSql2.length()-1)+")";

if(OperType.equals("update"))

opSql=updateSql.substring(0,updateSql.length()-1)+" "+whereSql;if(OperType.equals("delete"))

opSql="delete FROM "+tablename+" "+whereSql;

//已生成完整的sql語句opSql

try{sqlnrows=Stmt.executeUpdate(opSql);}

catch(SQLException e){out.println("SQLException:

"+opSql);}

4、特點

該方法對所有這種直接存儲的表單都統一使用本程序,具有通用性,不必對每個表單或每個數據表獨立開發相應程序,開發工作量非常少,調用也非常簡便。同時,在表結構變動時,不用修改DBdataStore.jsp程序。本程序也可改寫爲Servelet,調用格式爲<Form Name=Frm1 Method=Post Action="DBdataStoreServelet?tablename=table1&OperType=…">。

結束語

在Web應用中,如果表單數據在提交後,還需要服務器後台作進一步的數據校驗或處理,則需要采用第二種方法。但很多情況是用戶在表單中輸入或修改數據,在前台浏覽器端使用javascript對數據進行簡單校驗或處理,然後提交,在後台服務器端不作任何處理,直接將表單提交的數據存儲到數據庫的一個表中。這時候采用第三種方法非常簡便,可以大大減輕開發人員的工作量。

JSP中表單數據存儲的一種通用方法
  摘 要   本文以Oracle數據庫爲例,介紹了在采用JSP技術開發WEB應用時一種簡便通用的表單數據存儲處理方法,以減輕開發工作量,同時提供了主要的程序代碼。  引言  J2EE(Java 2 Enterprise Edition)技術已廣...查看完整版>>JSP中表單數據存儲的一種通用方法
 
新手看招:Linux系統下Tar基本安裝方法
1、將安裝文件拷貝至你的目錄中,如果是以root身份登錄上的,就將軟件拷貝至/root中。 #cp xxx.tar.gz /root 2、解壓縮。 #tar xvzf xxx.tar.gz 或直接雙擊解壓縮. 3、檢查編譯。 #./configure 4、檢查通過後,將生成...查看完整版>>新手看招:Linux系統下Tar基本安裝方法
 
新手看招:Linux系統下撥號上網方法介紹
Linux下通過gprs模塊撥號上網這幾天做了一下gprs撥號上網,模塊是西門子的mc39i。我的系統是fedora core 6。其實很簡單,我又有高手指導。 首先從/usr/share/doc/ppp-2.4.4/scripts中cp ppp-on,ppp-off,ppp-on-diale...查看完整版>>新手看招:Linux系統下撥號上網方法介紹
 
新手請教jsp連接數據庫的問題
我剛接觸JSP,試著連接數據庫,但去總出錯,請大家指教<%@ page contentType="text/html;charset=gb2312"%> <%@ page import="java.sql.*"%> <html> <body> <%Class.fo...查看完整版>>新手請教jsp連接數據庫的問題
 
新手看招:RHEL5系統下配置YUM源的方法
1. 安裝yum 2. 修改.repo文件 ccd /etc/yum.repos.d/ #vi CentOS-Base.repo 寫入一下內容: name=CentOS-5 - Base #mirrorlist=http://mirrorlist.centos.org/?release=$releasever5&arch=$basearch& repo=...查看完整版>>新手看招:RHEL5系統下配置YUM源的方法
 
JSP表單自動數據驗證組件簡介
  從jsp到servlet或者action過程中還有很多需要處理的事情:數據有效性驗證包括jsp頁面的javascript驗證和服務器端的驗證、對文件上傳的處理、文件上傳大小的控制、防止二次提交、multipart form的非文件字段的處理...查看完整版>>JSP表單自動數據驗證組件簡介
 
JSP服務器的安裝與配置(帶數據庫,新手專用)
下載的地址:http://java.sun.com/products/archive/j2se/1.4.2_06/index.html第一步:----安裝J2SDK:  到SUN官方站點(http://java.sun.com)下載J2SDK的安裝文件:j2sdk-1_4_2_04-windows-i586-p.exe,下載之後安裝...查看完整版>>JSP服務器的安裝與配置(帶數據庫,新手專用)
 
新手看招:Linux系統中的RAD工具概括介紹
Borland Delphi的未來越來越迷茫了,但是現在終于有開源的"Delphi"了: Lazarus for free pascal。 其實很早就有了,我一開始進入linux世界的時候,就稍微研究了一下,但那是的lazarus還不是很成熟。lazaru...查看完整版>>新手看招:Linux系統中的RAD工具概括介紹
 
實現小數據量和海量數據的通用分頁顯示存儲過程
實現小數據量和海量數據的通用分頁顯示存儲過程   建立一個web 應用,分頁浏覽功能必不可少。這個問題是數據庫處理中十分常見的問題。經典的數據分頁方法是:ADO 紀錄集分頁法,也就是利用ADO自帶的分頁功能(利用遊...查看完整版>>實現小數據量和海量數據的通用分頁顯示存儲過程
 
 
回到王朝網路移動版首頁