成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JSP表單在數據存儲中的一種通用方法

開發 后端
JSP表單是非常常用的一個模塊,其在數據存儲方面也有自己的優勢,那么如何使用JSP表單來解決繁重的業務數據存儲工作呢?本文將向你提供一種簡單有效的方法。

用JSP表單業務數據存儲到數據庫中的處理工作經常很繁重,其中一種主要的形式就是JSP表單數據存儲到數據庫,整個應用處理過程牽涉到大量的這種數據存儲操作,對每個表單都要單獨編寫相應的數據存儲程序,花費了開發人員大量的時間和精力。采用什么方法來減輕表單數據存儲的開發工作量是值得研究的問題。

兩種常見的表單數據存儲處理方法

1、對每一JSP表單都編寫相應的程序代碼

在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語句生成和執行。

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

  1. ﹤jsp:useBean id="table" class="table1_bean" /﹥  
  2. ﹤jsp:setProperty name="table" property="*" /﹥ 

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

然后調用table1_bean中insert、update、delete函數完成數據表存儲,并返回執行結果。如:

  1. ﹤%boolean success =table.insert(); %﹥ 

第一種方法簡單直觀,但對每一表單都需要編寫相應的數據處理程序。對稍微大一點的應用,表單數量可能很多,開發工作量很大,開發工作效率低。表結構變動如增加、減少字段時,需修改相應的數據處理程序。

第二種方法相對第一種簡便得多,每一數據表的數據處理由對應的JavaBean實現,JavaBean自動生成,不需編寫,表結構變動時只需重新生成新的JavaBean,經java編譯后覆蓋原java類即可。但該方法需要開發JavaBean自動生成程序,表結構變動時JavaBean需要重新生成和編譯。

介紹一種簡便通用的方法實現表單數據存儲

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

1、調用格式

在網頁中表單的Action調用方法如下:

  1. ﹤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) 建立表各列數據類型視圖

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

2) 建立表的關鍵列視圖

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

3、JSP表單主要程序代碼

1) 程序初始化

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

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

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

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

在操作類型為update時,網頁form表單中不對關鍵字段的數據進行修改。

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

3)非關鍵字段部分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  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)";  
  3. rs1=Stmt.executeQuery(strSql);//取非關鍵字段字段名和數據類型  
  4. while(rs1.next()){  
  5.   fieldname=rs1.getString("column_name");Datatype=rs1.getString("data_type");   sFieldValue=request.getParameter(fieldname.toLowerCase());//若表單未提交該字段的值,則忽略該字段的處理  
  6.  if((sFieldValue!=null)){  
  7.   //生成insert語句=insSql1+insSql2 即insert into tablename(… 和 values(…  
  8.   if(OperType.equals("insert")){ insSql1+=fieldname+",";  
  9.   if(Datatype.equals("DATE")){  
  10.    insSql2+= "To_Date('" + sFieldValue + "','YYYY-MM-DD'),";  
  11.   } else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){  
  12.    insSql2+="'" + sFieldValue+"',";}else /*NUMBER,FLOAT*/ insSql2+= sFieldValue+",";}  
  13.   //生成update語句=updateSql+whereSql 即update tablename set ... where  fieldname=... if(OperType.equals("update")){  
  14.  if(Datatype.equals("DATE")){  
  15.   updateSql+=fieldname+"=To_Date('" + sFieldValue + "','YYYY-MM-DD'),";  
  16.  }else if(Datatype.equals("VARCHAR2") || Datatype.equals("CHAR")){  
  17.   updateSql+=fieldname+"='" + sFieldValue,1}+"',";}else /*NUMBER,FLOAT*/ updateSql+=fieldname+"="+sFieldValue+",";} ))  
  18.  rs1.close();  
  19.  

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

  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:"+opSql);}  
  9.  

4、使用JSP表單特點

該方法對所有這種直接存儲的表單都統一使用本程序,具有通用性,不必對每個表單或每個數據表獨立開發相應程序,開發工作量非常少,調用也非常簡便。同時,在表結構變動時,不用修改DBdataStore.jsp程序。本程序也可改寫為Servelet,調用格式為

  1. ﹤Form Name=Frm1 Method=Post Action="DBdataStoreServelet?tablename=table1&OperType=…"﹥ 

結束語

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

【編輯推薦】

  1. 對JSP中的內置對象簡單概述
  2. JSP教程基礎之腳本的使用
  3. JSP教程基礎篇之HTML表單演示
  4. JSP教程基礎篇之簡單首頁制作
  5. JSP入門之網站環境搭建的步驟
責任編輯:仲衡 來源: 互聯網
相關推薦

2009-07-02 15:12:39

2009-07-02 11:29:22

JSP技術表單數據存儲

2021-06-11 00:11:23

GPS數據協議

2021-06-04 08:58:41

Linux運維Linux系統

2023-02-26 23:10:09

存儲Linux架構

2023-07-25 15:10:36

Linux存儲

2023-05-11 07:30:10

KV存儲GC優化

2017-10-25 08:44:03

NVMe SSD數據存儲

2018-12-14 14:30:12

安全檢測布式系測試

2011-07-04 17:53:48

快速測試

2024-03-22 09:21:07

自動駕駛訓練

2010-03-26 13:34:47

CentOS安裝

2011-04-06 10:09:56

MySQL數據庫安裝

2020-05-19 17:07:09

Spark測試數據計算

2022-04-20 08:00:00

深度學習數據集Hub

2019-12-31 14:21:00

數據挖掘關系網絡數據

2018-02-08 08:11:41

2020-12-23 10:10:23

Pythonweb代碼

2022-06-22 09:44:41

Python文件代碼

2022-07-07 10:33:27

Python姿勢代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 色偷偷噜噜噜亚洲男人 | 亚洲精品电影在线观看 | 国产精品永久免费 | 97精品超碰一区二区三区 | 国产高清视频一区二区 | 亚洲欧美男人天堂 | 91.xxx.高清在线| 久久亚洲一区二区三区四区 | 免费精品视频 | 国产成人综合在线 | 伊人啪啪网 | 国产在线中文字幕 | 成人一区av偷拍 | 免费精品 | 中文天堂在线观看 | 欧美精品久久久久 | 亚洲精品白浆高清久久久久久 | 天天操天天射天天舔 | 精品在线观看入口 | 密室大逃脱第六季大神版在线观看 | 噜久寡妇噜噜久久寡妇 | 精品综合久久久 | 91在线看片 | 日韩成人在线电影 | 国产乱码高清区二区三区在线 | 欧美日韩精品一区二区 | 91中文视频| 精品免费国产一区二区三区四区介绍 | 在线免费国产视频 | 欧美色999 | 久久精品小短片 | 久久精品综合 | a级大片免费观看 | 久久精品中文 | 韩日一区| 国产激情一区二区三区 | 婷婷色婷婷| 国产成人精品一区二区三区网站观看 | 欧美日韩在线精品 | 国产精品视频综合 | 国产精品毛片av一区 |