亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

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

2019-11-18 16:27:45
字體:
來源:轉載
供稿:網友

  摘 要

  本文以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對數據進行簡單校驗或處理,然后提交,在后臺服務器端不作任何處理,直接將表單提交的數據存儲到數據庫的一個表中。這時候采用第三種方法非常簡便,可以大大減輕開發人員的工作量。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品第一页| 精品久久久久久中文字幕一区奶水| 日产精品99久久久久久| 亚洲成年网站在线观看| 国产美女久久久| 国产亚洲精品久久久优势| 日韩电影第一页| 成人xxxx视频| 欧美第一淫aaasss性| 国产丝袜一区视频在线观看| 国产自产女人91一区在线观看| 97视频在线观看亚洲| 欧美体内谢she精2性欧美| 国产成人精品视频在线观看| 久久天天躁夜夜躁狠狠躁2022| 亚洲电影第1页| 国产97在线视频| 在线午夜精品自拍| 国产日韩中文在线| 欧美资源在线观看| 国产精品99久久久久久白浆小说| 国产成人午夜视频网址| 亚洲一区二区三区乱码aⅴ| 91久久久亚洲精品| 91sao在线观看国产| 欧美色图在线视频| 中文字幕精品—区二区| 91po在线观看91精品国产性色| 国产狼人综合免费视频| 成人精品在线观看| 成人久久一区二区| 久久久电影免费观看完整版| 精品久久久久久亚洲精品| 国产精品一区专区欧美日韩| 亚洲精品成人久久电影| 亚洲深夜福利在线| 久热精品视频在线观看| 亚洲品质视频自拍网| 最近2019免费中文字幕视频三| 91av视频在线免费观看| 亚洲欧美日韩中文视频| 北条麻妃99精品青青久久| 亚洲欧美日韩国产精品| 亚洲区一区二区| 日韩高清免费在线| 国产欧美在线看| 亚州精品天堂中文字幕| 色琪琪综合男人的天堂aⅴ视频| 精品久久久香蕉免费精品视频| 午夜精品一区二区三区在线播放| 亚洲人成网站免费播放| 中文.日本.精品| 国产极品jizzhd欧美| 成人黄色生活片| 中文字幕国产精品久久| 超碰精品一区二区三区乱码| 欧美最猛黑人xxxx黑人猛叫黄| 国产精品伦子伦免费视频| 久久影视电视剧免费网站| 综合欧美国产视频二区| 久久91亚洲精品中文字幕| 欧美中文字幕第一页| 免费不卡欧美自拍视频| 国语自产精品视频在线看抢先版图片| 美女国内精品自产拍在线播放| 欧美精品在线免费观看| 国产精品极品美女在线观看免费| 2019中文字幕免费视频| 国产精品视频免费在线观看| 欧美色另类天堂2015| 亚洲美女动态图120秒| 精品国产一区二区三区久久狼5月| 国产成人精品久久久| 这里只有精品视频在线| 国产一区二区三区在线观看网站| 亚洲精品一区在线观看香蕉| 琪琪亚洲精品午夜在线| 欧美亚洲午夜视频在线观看| 91成人天堂久久成人| 国产suv精品一区二区三区88区| 久久久久久国产精品久久| 国产精品久久久久久久app| 欧美精品在线极品| 国产亚洲精品91在线| 深夜精品寂寞黄网站在线观看| 亚洲综合精品一区二区| 91在线直播亚洲| 欧美日韩在线观看视频| 亚洲国产精品yw在线观看| 欧美亚洲激情视频| 狠狠做深爱婷婷久久综合一区| 日韩欧美国产激情| 欧美精品videos另类日本| 欧美日韩一区免费| 中文字幕不卡在线视频极品| 九九热精品视频在线播放| 久久精品国产91精品亚洲| 日韩黄色在线免费观看| 91欧美日韩一区| 国产精品国语对白| 色久欧美在线视频观看| 国产精品99久久久久久久久久久久| 欧美激情精品久久久久久| 精品视频在线播放色网色视频| 久久成人精品电影| 久久久噜噜噜久久久| 91在线视频九色| 91网站免费观看| 日韩av在线免费看| 国产精品吊钟奶在线| 懂色av影视一区二区三区| 亚洲无限av看| 国产精品国产三级国产专播精品人| 亚洲欧美精品在线| 午夜精品一区二区三区视频免费看| 狠狠色噜噜狠狠狠狠97| 亚洲精品一区二区三区不| 日韩av在线一区| 红桃视频成人在线观看| 亚洲美女精品成人在线视频| 欧美精品手机在线| 国产精品福利片| 午夜剧场成人观在线视频免费观看| 国产日韩欧美夫妻视频在线观看| 国产成人短视频| 亚洲丁香婷深爱综合| 国产精品白丝jk喷水视频一区| 国产不卡一区二区在线播放| 久久伊人精品视频| 成人黄在线观看| 国产精品你懂得| 亚洲国产成人精品女人久久久| 国产aaa精品| 国模吧一区二区三区| 国产成人精品久久| 久久久久久久电影一区| 久久网福利资源网站| 日韩福利在线播放| 亚洲图片制服诱惑| 国产日本欧美一区| 欧美一区二区三区免费视| 日韩在线视频线视频免费网站| 日韩风俗一区 二区| 午夜免费久久久久| 欧美在线一级视频| 精品久久久久久久久久| 91精品国产自产在线观看永久| 国产亚洲精品日韩| 亚洲一区二区三区香蕉| 97在线视频国产| 国产精选久久久久久| 中文字幕亚洲欧美日韩在线不卡| 一区二区三区在线播放欧美| 亚洲男人天堂2023| 精品自拍视频在线观看| 日韩国产精品一区| 亚洲人成在线观| 91精品国产精品| 久久久久久网站| 中文字幕一区二区精品| 欧美黑人一区二区三区| 欧美性猛交丰臀xxxxx网站| 成人观看高清在线观看免费| 精品在线小视频|