http://www.educity.cn 作者:佚名 来源:希赛教育
基于上面的规格我们可以非常轻松写一个javabean。代码如下:

    /**
    * @version: 1.1
    * @Time: 2005.03.02
    */
    package com.river.page ;
    import java.util.*;
    import javax.servlet.http.HttpServletRequest;
    public class PageUtil {
    private HttpServletRequest request = null ;
    public PageUtil(){
    }
    public void init(HttpServletRequest _request){
    this.request = _request ;
    }
    public void clear(){
    if(this.request != null){
    this.request = null ;
    }
    }
    public String get(String elementName){
    if(request == null || request.getParameter(elementName) == null){
    return “”;
    }else{
    return request.getParameter(elementName);
    }
    }
    public String get(HttpServletRequest _request,String elementName){
    init(_request);
    return get(elementName);
    }
    public String getSQL(HttpServletRequest _request){
    init(_request);
    return getSQL();
    }
    public String getSQL(){
    String sqlstr = “”;
    String c_table = get(“c_table”);
    String c_genre = get(“c_genre”);
    String c_where = get(“c_where”);
    if(c_genre == null || c_genre.equals(“”)){
    return “the action is null/empty”;
    }
    if(c_table == null || c_table.equals(“”)){
    return “unknow table/empty” ;
    }
    if(c_genre.equalsIgnoreCase(“INSERT”)){
    java.util.Enumeration arg_names = request.getParameterNames();
    String colstr = “”,valstr = “”;
    String arg_name,pre_name,end_name ;
    while(arg_names.hasMoreElements()){
    arg_name = String.valueOf(arg_names.nextElement());
    if(arg_name.length() < 2){
    continue;
    }
    pre_name = arg_name.substring(0,2);
    end_name = arg_name.substring(2);
    if(pre_name.equalsIgnoreCase(“i_”)){
    colstr = colstr+“,”+end_name;
    if(get(arg_name).equals(“”)){
    valstr = valstr+“,NULL”;
    }else{
    valstr = valstr + “,” + String.valueOf(get(arg_name));
    }
    }else if(pre_name.equalsIgnoreCase(“s_”)){
    colstr = colstr+“,”+end_name;
    if(get(arg_name).equals(“”)){
    valstr = valstr+“,NULL”;
    }else{
    valstr = valstr+“,‘”+get(arg_name).replaceAll(“’”,“‘’”)+“‘”;
    }
    }
    }
    if(!colstr.equals(“”)){
    colstr = colstr.substring(1);
    valstr = valstr.substring(1);
    }
    sqlstr = “INSERT INTO ”+c_table+“ (”+colstr+“) VALUES (”+valstr+“)”;
    return sqlstr;
    }else if(c_genre.equalsIgnoreCase(“UPDATE”)){
    java.util.Enumeration arg_names = request.getParameterNames();
    String colstr = “”;
    String arg_name,pre_name,end_name ;
    while(arg_names.hasMoreElements()){
    arg_name = String.valueOf(arg_names.nextElement()).trim();
    if(arg_name.length() < 2){
    continue;
    }
    pre_name = arg_name.substring(0,2);
    end_name = arg_name.substring(2);
    if(pre_name.equalsIgnoreCase(“i_”)){
    if(get(arg_name).equals(“”)){
    colstr += “,”+end_name+“=NULL”;
    }else{
    colstr += “,”+end_name+“=”+get(arg_name);
    }
    }else if(pre_name.equalsIgnoreCase(“s_”)){
    if(get(arg_name).equals(“”)){
    colstr += “,”+end_name+“=”+get(arg_name);
    }else{
    colstr += “,”+end_name+“=’”+get(arg_name).replaceAll(“‘”,“'’”)+“‘”;
    }
    }
    }
    if(!colstr.equals(“”)){
    colstr = colstr.substring(1);
    }
    sqlstr = “UPDATE ”+c_table+“ SET ”+colstr;
    if(!c_where.equals(“”)){
    sqlstr += “ WHERE ”+c_where;
    }
    return sqlstr;
    }else if(c_genre.equalsIgnoreCase(“DELETE”)){
    sqlstr = “DELETE FROM ”+c_table;
    if(c_where != null && !c_where.equals(“”)){
    sqlstr += “ WHERE ”+c_where;
    }
    }else{
    com.river.debug.Debug.show(“unknow action type : ”+c_genre);
    return null;
    }
    return sqlstr;
    }
    public String toString(){
    return “version 1.0, date 2005.03.02, author river”;
    }
    }

    这样我们就可以根据页面元素的命名来指导SQL语句的生成。这样做有很多的明显的好处:

    1.减少编码工作,对于元素很多表单,用不着我们去写一大堆的代码,不用去担心哪个元素落下了,元素名有没有些错,单引号有没有处理。

    2.通用、稳定、易于维护,javabean固有的优点,就不用太多的说明了。

    3.分离表层的表单内容与逻辑层SQL语句的构造。设想一下,如果我们数据库表结构有调整时,那么我们只要修改一下表单就好了,根本就不用理原来写好的逻辑处理。附带着再说一句,设想如果我们再写一个类自动执行SQL,那么对于一些基本的增、删、改操作都可以映射到同一个action里面来处理,且不是很爽?

    当然,这样做的缺点也是有的。那就是有一定的性能损耗。特别是碰到表单元素非常多时。但是我想对于那些不是很“苛刻”的项目这点损耗是值得的。