JSP中表单数据存储的一种通用要收 - 糊心小直 - hylcb - 战讯专客

携程
两种常睹的表单数据存储处置方法

  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=…">。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值