自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JSP表單數(shù)據(jù)存儲的通用方法

開發(fā) 后端
本文以O(shè)racle數(shù)據(jù)庫為例,介紹了在采用JSP技術(shù)開發(fā)WEB應(yīng)用時(shí)一種簡便通用的JSP表單數(shù)據(jù)存儲處理方法,以減輕開發(fā)工作量,同時(shí)提供了主要的程序代碼。

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ù)庫,整個(gè)應(yīng)用處理過程牽涉到大量的這種數(shù)據(jù)存儲操作,對每個(gè)表單都要單獨(dú)編寫相應(yīng)的數(shù)據(jù)存儲程序,花費(fèi)了開發(fā)人員大量的時(shí)間和精力。采用什么方法來減輕表單數(shù)據(jù)存儲的開發(fā)工作量是值得研究的問題。

兩種常見的JSP表單數(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ù)表自動生成一個(gè)JavaBean程序代碼

數(shù)據(jù)庫系統(tǒng)必須支持用戶能夠讀取表結(jié)構(gòu),并識別關(guān)鍵字段。利用面向?qū)ο罂焖匍_發(fā)工具,如PowerBuilder、Delphi等,自行開發(fā)一個(gè)java代碼自動生成程序。在該程序中讀取數(shù)據(jù)庫表的結(jié)構(gòu):字段名、數(shù)據(jù)類型、數(shù)據(jù)長度,自動生成一個(gè)JavaBean代碼。在該代碼中定義與表中字段對應(yīng)的同名變量,建立所有變量的setValue和getValue方法,建立insert、update、delete函數(shù)分別處理insert、update、delete的SQL語句生成和執(zhí)行。

在表單提交的數(shù)據(jù)處理頁面中,編寫如下代碼,將表單數(shù)據(jù)存儲到JavaBean中:

  1. <jsp:useBean id="table" class="table1_bean" />   
  2.  
  3. <jsp:setProperty name="table" property="*" />   

(注:table1_bean為上述自動生成的對應(yīng)某一個(gè)表的JavaBean)

然后調(diào)用table1_bean中insert、update、delete函數(shù)完成數(shù)據(jù)表存儲,并返回執(zhí)行結(jié)果。如:

  1. <%boolean success =table.insert(); %>  

JSP表單數(shù)據(jù)存儲的這兩種方法中,第一種方法簡單直觀,但對每一表單都需要編寫相應(yīng)的數(shù)據(jù)處理程序。對稍微大一點(diǎn)的應(yīng)用,表單數(shù)量可能很多,開發(fā)工作量很大,開發(fā)工作效率低。表結(jié)構(gòu)變動如增加、減少字段時(shí),需修改相應(yīng)的數(shù)據(jù)處理程序。

第二種方法相對第一種簡便得多,每一數(shù)據(jù)表的數(shù)據(jù)處理由對應(yīng)的JavaBean實(shí)現(xiàn),JavaBean自動生成,不需編寫,表結(jié)構(gòu)變動時(shí)只需重新生成新的JavaBean,經(jīng)java編譯后覆蓋原java類即可。但該方法需要開發(fā)JavaBean自動生成程序,表結(jié)構(gòu)變動時(shí)JavaBean需要重新生成和編譯。

介紹一種簡便通用的方法實(shí)現(xiàn)JSP表單數(shù)據(jù)存儲

在WEB應(yīng)用開發(fā)中,很多表單在經(jīng)過前臺瀏覽器端簡單的數(shù)據(jù)校驗(yàn)后,提交后臺服務(wù)器,服務(wù)器對數(shù)據(jù)不用作任何處理直接將數(shù)據(jù)存儲到一個(gè)數(shù)據(jù)表中。對這種情況,我們可以只編寫一個(gè)程序,對這些表單統(tǒng)一處理,將數(shù)據(jù)存儲到相應(yīng)的一個(gè)數(shù)據(jù)表中。該方法同樣要求數(shù)據(jù)庫系統(tǒng)支持表結(jié)構(gòu)讀取和關(guān)鍵字段識別。我們采用JSP技術(shù)編寫該程序,程序文件取名為DbdataStore.jsp。

1、調(diào)用格式

在網(wǎng)頁中表單的Action調(diào)用方法如下:

  1. <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ù)類型視圖

  1. CREATE OR REPLACE VIEW v_dbstru AS SELECT table_name,column_name,data_type,data_length,data_precision,data_scale,column_id   
  2.  
  3. FROM all_tab_columns WHERE owner='user1';//user1為數(shù)據(jù)表的屬主。   

2) 建立表的關(guān)鍵列視圖

  1. CREATE OR REPLACE VIEW v_pkey_column AS   
  2.  
  3. SELECT b.table_name,b.column_name,b.position   
  4.  
  5. FROM all_constraints a,all_cons_columns b   
  6.  
  7. WHERE a.owner=b.owner AND a.constraint_name=b.constraint_name AND a.owner='user1'  AND a.constraint_type='P';  

3、主要程序代碼

1) 程序初始化

  1. String tablename=request.getParameter("tablename");//提取表名   
  2.  
  3. String OperType=request.getParameter("OperType");//提取操作類型   
  4.  
  5. String sFieldValue="";//存放表單提交的字段數(shù)據(jù)值   
  6.  
  7. String fieldname="",Datatype="" //存放字段名,字段數(shù)據(jù)類型   
  8.  
  9. int iFieldvalue=0;   
  10.  
  11. String updateSql="",whereSql=" where ",insSql1="",insSql2="",opSql="",strSql ="";   
  12.  
  13. ResultSet rs1=null,rs2=null;   
  14.  
  15. insSql1="insert into "+tablename+" (";   
  16.  
  17. insSql2="values(";   

2)生成sql語句關(guān)鍵字段部分

生成insert語句關(guān)鍵字段部分,如:insert into table1(id 和 values(100));

只使用關(guān)鍵字段生成update,delete語句where部分,如:where id=100;

在操作類型為update時(shí),網(wǎng)頁form表單中不對關(guān)鍵字段的數(shù)據(jù)進(jìn)行修改。

  1. rs1=Stmt.executeQuery("SELECT column_name FROM v_pkey_column WHERE table_name='"+tablename+"'");  
  2. //取關(guān)鍵字段字段名  
  3. while(rs1.next()){   
  4.  fieldname=rs1.getString("column_name");  
  5.  rs2=Stmt.executeQuery("SELECT data_type FROM v_dbstru WHERE  table_name='"+tablename+"'   
  6. AND column_name='"+fieldname+"'");//取關(guān)鍵字段數(shù)據(jù)類型  
  7.  if(rs2.next()){  
  8.   Datatype=rs2.getString("data_type");  
  9.   sFieldValue=request.getParameter(fieldname.toLowerCase());  
  10.   //生成insert語句關(guān)鍵字段部分   
  11.   if(OperType.equals("insert")){   
  12.    insSql1+=fieldname+",";  
  13.    if((sFieldValue==null) ){  
  14.     //表單未提交關(guān)鍵字段數(shù)據(jù)值時(shí),本文只按數(shù)字型處理,數(shù)據(jù)值按下一流水號計(jì)算。   
  15.     rs2= Stmt. executeQuery("SELECT max("+fieldname+")+1 FROM "+tablename);  
  16. rs2. next();iFieldvalue=rs2.getInt(1);insSql2+=Integer.toString(iFieldvalue)+",";  
  17. }else if(Datatype.equals("DATE")){  
  18.     insSql2+= "To_Date('" + sFieldValue + "','YYYY-MM-DD'),";  
  19.    }else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){  
  20. insSql2+="'" + sFieldValue+"',";}  
  21.    else /*NUMBER,F(xiàn)LOAT */ insSql2+=sFieldValue+",";}   
  22.    //生成update,delete語句where部分:where fieldname=... AND   
  23.    if(OperType.equals("update") || OperType.equals("delete")){   
  24.     if(Datatype.equals("DATE")){   
  25.      whereSql+=fieldname+"=To_Date('" + sFieldValue + "','YYYY-MM-DD') AND ";  
  26.     }else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){   
  27.      whereSql+=fieldname+"='" + sFieldValue+"' AND ";}  
  28.     else /*NUMBER,F(xiàn)LOAT */ whereSql+=fieldname+"="+ sFieldValue+" AND ";}   
  29.   }  
  30.  }  
  31. whereSql=whereSql.substring(0,whereSql.length()-4); 

3)非關(guān)鍵字段部分sql語句生成

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

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

  1. updateSql="update "+tablename+" set ";  
  2. strSql="SELECT column_name,data_type,data_length,data_precision,data_scale FROM   
  3. v_dbstru a "+"where table_name='"+tablename+"'   
  4. AND a.column_name not in (SELECT   
  5. b.column_name FROM v_pkey_column b where b.table_name=a.table_name)";  
  6. rs1=Stmt.executeQuery(strSql);//取非關(guān)鍵字段字段名和數(shù)據(jù)類型  
  7. while(rs1.next()){   
  8.  fieldname=rs1.getString("column_name");Datatype=rs1.getString("data_type");  
  9.    sFieldValue=request.getParameter(fieldname.toLowerCase());  
  10. //若表單未提交該字段的值,則忽略該字段的處理   
  11.  if((sFieldValue!=null)){   
  12.   //生成insert語句=insSql1+insSql2 即insert into tablename(… 和 values(…   
  13.   if(OperType.equals("insert")){ insSql1+=fieldname+",";  
  14.   if(Datatype.equals("DATE")){   
  15.    insSql2+= "To_Date('" + sFieldValue + "','YYYY-MM-DD'),";  
  16.   } else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){  
  17.    insSql2+="'" + sFieldValue+"',";}else /*NUMBER,F(xiàn)LOAT*/ insSql2+= sFieldValue+",";}   
  18.   //生成update語句=updateSql+whereSql 即update tablename set ... where   
  19. fieldname=... if(OperType.equals("update")){   
  20. if(Datatype.equals("DATE")){  
  21. updateSql+=fieldname+"=To_Date('" + sFieldValue + "','YYYY-MM-DD'),";  
  22. }else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){   
  23. updateSql+=fieldname+"='" + sFieldValue,1}+"',";}else /*NUMBER,F(xiàn)LOAT*/   
  24. updateSql+=fieldname+"="+sFieldValue+",";} ))   
  25.  rs1.close(); 

4)生成完整的sql語句并執(zhí)行

  1. if(OperType.equals("insert"))   
  2.  opSql=insSql1.substring(0,insSql1.length()-1)+")"+insSql2.substring(0,insSql2.length()-1)+")";  
  3. if(OperType.equals("update"))  
  4.  opSql=updateSql.substring(0,updateSql.length()-1)+" "+whereSql;if(OperType.equals("delete"))  
  5.  opSql="delete FROM "+tablename+" "+whereSql;  
  6. //已生成完整的sql語句opSql  
  7. try{sqlnrows=Stmt.executeUpdate(opSql);}   
  8. catch(SQLException e){out.println("SQLException:  
  9. "+opSql);} 

4、特點(diǎn)

該方法對所有這種直接存儲的表單都統(tǒng)一使用本程序,具有通用性,不必對每個(gè)表單或每個(gè)數(shù)據(jù)表獨(dú)立開發(fā)相應(yīng)程序,開發(fā)工作量非常少,調(diào)用也非常簡便。同時(shí),在表結(jié)構(gòu)變動時(shí),不用修改DBdataStore.jsp程序。本程序也可改寫為Servelet,調(diào)用格式為<Form Name=Frm1 Method=Post Action="DBdataStoreServelet?tablename=table1&OperType=…">。

結(jié)束語

在Web應(yīng)用中,如果表單數(shù)據(jù)在提交后,還需要服務(wù)器后臺作進(jìn)一步的數(shù)據(jù)校驗(yàn)或處理,則需要采用第二種方法。但很多情況是用戶在表單中輸入或修改數(shù)據(jù),在前臺瀏覽器端使用javascript對數(shù)據(jù)進(jìn)行簡單校驗(yàn)或處理,然后提交,在后臺服務(wù)器端不作任何處理,直接將表單提交的數(shù)據(jù)存儲到數(shù)據(jù)庫的一個(gè)表中。這時(shí)候采用第三種方法進(jìn)行JSP表單數(shù)據(jù)存儲非常簡便,可以大大減輕開發(fā)人員的工作量。

【編輯推薦】

  1. JSP在電子商務(wù)網(wǎng)站開發(fā)的運(yùn)用應(yīng)用發(fā)展方向
  2. 入侵JSP網(wǎng)站服務(wù)器
  3. 基于JSP技術(shù)的網(wǎng)絡(luò)
  4. JSP變量在規(guī)范中稱作范圍變量
  5. ASP優(yōu)點(diǎn)和JSP優(yōu)點(diǎn)總結(jié)
責(zé)任編輯:王觀 來源: 中國IT實(shí)驗(yàn)室
相關(guān)推薦

2009-07-02 11:29:22

JSP技術(shù)表單數(shù)據(jù)存儲

2009-07-01 18:39:17

JSP表單

2009-07-03 14:41:03

2016-09-27 19:28:37

2009-12-01 18:02:41

PHP表單數(shù)組

2011-07-22 09:51:51

iPhone FROM 表單

2021-09-14 18:33:39

React 數(shù)據(jù)交互

2010-06-10 18:08:58

2016-12-13 13:54:10

EasyUI form數(shù)據(jù)加載

2023-04-26 08:18:48

FormPrompt表單更改

2012-06-05 10:15:43

jQuery

2011-09-01 13:43:23

VC調(diào)用SQL Ser

2009-07-03 13:24:56

JSP表單

2009-07-02 13:10:09

JSP技術(shù)

2009-05-08 09:17:48

動態(tài)數(shù)據(jù)庫圖片

2021-12-21 09:35:59

CSV存儲數(shù)據(jù)Python

2009-06-30 11:18:16

HTML表單JSP教程

2009-06-22 14:57:09

2009-07-01 18:17:32

JSP處理Cookie

2009-06-30 09:16:45

數(shù)據(jù)庫存儲JSP文件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號