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

首頁 > 編程 > JSP > 正文

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

2024-09-05 00:20:33
字體:
來源:轉載
供稿:網友

  引言

  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調用方法如下:

 ?。糵orm 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中逐一提取表單提交的對應字段名的數據值,若表單中未定義輸入,得到的值為空值,則對該字段不作處理。

  • 網站運營seo文章大全
  • 提供全面的站長運營經驗及seo技術!
  • |||

      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));

    注冊會員,創建你的web開發資料庫,|||

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

    商業源碼熱門下載www.html.org.cn

    發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
    26uuu国产精品视频| 97在线看免费观看视频在线观看| 亚洲成人激情在线| 久久成人精品电影| 欧美激情xxxxx| 欧美日韩一区二区在线播放| 97成人精品视频在线观看| 成人精品一区二区三区电影黑人| 国产精品国产三级国产aⅴ浪潮| 成年无码av片在线| 欧美大尺度电影在线观看| 亚洲国模精品一区| 深夜福利亚洲导航| 国产精品入口日韩视频大尺度| 欧美一区二区三区……| 欧美中文在线字幕| 亚洲大胆美女视频| 色黄久久久久久| 成人有码在线播放| 欧美日韩国产精品| 最近日韩中文字幕中文| 欧美日韩一区二区免费视频| 伊人伊成久久人综合网小说| 久久在线精品视频| 亚洲精品国产综合久久| 久久免费视频这里只有精品| 国产免费一区二区三区香蕉精| 亚洲一区二区三区四区在线播放| 国产精品对白刺激| 国产精品视频网址| 欧美日本在线视频中文字字幕| 久久久精品国产一区二区| 欧美另类暴力丝袜| 久久av在线看| 日韩电影中文字幕av| 久久久久久久久91| 成人中文字幕在线观看| 国产精品日韩av| 奇米成人av国产一区二区三区| 国模私拍视频一区| 国产精品麻豆va在线播放| 91夜夜揉人人捏人人添红杏| 综合国产在线观看| 成年人精品视频| 欧美激情视频三区| 成人h视频在线观看播放| 亚洲аv电影天堂网| 欧美激情国产高清| 国产玖玖精品视频| 亚洲成人黄色在线| 久久久久久久久久久亚洲| 色婷婷综合久久久久中文字幕1| 国产69精品99久久久久久宅男| 精品国产一区久久久| 亚洲精品日产aⅴ| 欧美日本中文字幕| 国内外成人免费激情在线视频| 亚洲美女中文字幕| 久久久久久国产| 午夜精品久久久久久久白皮肤| 久久精品电影一区二区| 亚洲欧美一区二区三区四区| 亚洲精品成人av| 热久久免费视频精品| 91免费精品国偷自产在线| 久久精品国产成人精品| 不用播放器成人网| 欧美一级黄色网| 热99精品只有里视频精品| 亚洲免费小视频| 国产精品9999| 欧洲成人免费视频| 一区二区三区回区在观看免费视频| 欧美日韩一区二区免费在线观看| 午夜精品蜜臀一区二区三区免费| 法国裸体一区二区| 国产在线观看91精品一区| 色系列之999| 久久综合久久八八| 日韩国产高清视频在线| 午夜精品久久久久久久99热| 韩国v欧美v日本v亚洲| 色偷偷噜噜噜亚洲男人的天堂| 亚洲小视频在线观看| 精品激情国产视频| 久久精品国产亚洲精品| 亚洲日韩欧美视频一区| 亚洲国内精品在线| 91av在线影院| 亚洲黄色有码视频| 中日韩午夜理伦电影免费| 欧美俄罗斯性视频| 日韩中文理论片| 日韩男女性生活视频| 日韩极品精品视频免费观看| 精品一区二区亚洲| 日韩一区二区在线视频| 日本一本a高清免费不卡| 亚洲色图偷窥自拍| 精品亚洲一区二区| 国产精品专区第二| 俺去亚洲欧洲欧美日韩| 成人国产在线视频| 91久久精品日日躁夜夜躁国产| 国产丝袜精品视频| 亚洲人成电影网| 亚洲精品日韩av| 一区二区三区国产在线观看| 久久久久久噜噜噜久久久精品| 亚洲人成网在线播放| 国产精品久久久久99| 精品亚洲一区二区三区四区五区| 国产精品高潮粉嫩av| 久久精品国产久精国产思思| 欧美成人久久久| 国产精品一区二区三区久久久| 久久天天躁狠狠躁夜夜躁2014| 日本韩国在线不卡| 国产视频精品一区二区三区| 国产午夜精品理论片a级探花| 国产精品自拍偷拍视频| 亚洲激情小视频| www.国产精品一二区| 一夜七次郎国产精品亚洲| 色一情一乱一区二区| 欧美高清性猛交| 日韩激情av在线免费观看| 亚洲区bt下载| 热久久99这里有精品| 中文字幕欧美日韩精品| 久久天天躁狠狠躁夜夜躁| www.色综合| 亚洲美女久久久| 国产伦精品一区二区三区精品视频| 日韩在线观看av| 亚洲欧美中文日韩在线| 欧美一级视频一区二区| 日韩欧美精品网站| 亚洲精品午夜精品| 亚洲欧美另类人妖| 亚洲影视中文字幕| 大量国产精品视频| 正在播放国产一区| 国产成+人+综合+亚洲欧美丁香花| 久久久精品美女| 欧美自拍大量在线观看| 日韩视频在线一区| 亚洲最大的av网站| 91精品国产高清自在线| 久久亚洲精品视频| 欧美日韩国产一中文字不卡| 亚洲国产美女久久久久| 亚洲精品视频久久| 国产日韩中文在线| 不卡中文字幕av| 国产视频在线一区二区| 丝袜亚洲欧美日韩综合| 国产欧美日韩亚洲精品| 亚洲欧美另类自拍| 欧美wwwwww| 亚洲人成网站免费播放| 国产精品你懂得| 韩国三级电影久久久久久| 亚洲桃花岛网站|