首页 | 互联网 | IT动态 | Cisco | Windows | Linux | Java | .Net | Oracle | 华为 | 存储世界 | 服务器 | 网络设备 | IDC | 安全 | 求职招聘
IT培训 | 数字网校 | 技术专题 | 电子书下载 | 教学视频 | 网页设计 | 平面设计 | 解决方案 | 直播室 | 虚拟考场 | 搜索 | 博客 | 沙龙 | 论坛
中国IT实验室Linux频道
中国IT教育
 
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> J2EE >> Servlet/Jsp >> 文章正文

介绍JSP中表单数据存储应用的一种通用方法

文章来源中国IT实验室收集整理 作者佚名 更新时间2008-3-27 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

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

上一页  [1] [2] [3] 下一页  

【责编:Ken】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题
 ·展现C#世界 C#程序设计专题
 ·Java入门 Tomcat的配置技巧精华专题
 ·Oracle RMAN物理备份技术详解
 ·JAVA开发利器——JBuilder知多少
 ·Hello,web2.0技术进阶专题
 今日更新
 社区讨论
 博客论点
 频道精选
 Java 频道导航