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

首頁 > 學院 > 開發設計 > 正文

J2EE應用程序中SQL語句自動構造方法

2019-11-18 11:05:15
字體:
來源:轉載
供稿:網友

  INSERT、DELETE、UPDATE 三種SQL語句是數據庫技術的三大基本語句。 在通常的web開發中對它的處理可以說是無處不在. 假如簡單的都用手工來構造這些SQL語句的話, 一方面給我們的開發帶來很大的工作量, 另一方面系統靈活性受到很大的限制。那么能不能基于某種規則讓系統自動從頁面表單中取出元素構造出SQL語句呢? 首先讓我們看看一般INSERT、DELETE、UPDATE 三種語句的基本形式:

INSERT INTO table_name (col_1,col_2,col_3,) VALUES (value_1,value_2,value_3 …)
DELETE FROM table_name WHERE col_n=value_n
UPDATE table_name SET col_1=value_1,col_2=value_2,col_3=value_3 WHERE col_x=value_x

   我們知道,借用j2ee中的request.getParameterNames()方法可以讀到表單中的所有元素的名稱,有了元素名稱借用request.getParameter(elementName)方法可以獲取該元素的值。假設在開發中我們讓頁面元素的名稱和底層數據庫表的字段名一致。那么在這三種語句中col_n 和 value_n 對我們來說就不是未知的,未知的數據就剩下了 table_name,col_x和value_x ?,F在假如我們寫一個方法,傳入request對象,再把table_name,col_x,value_x作為參數傳入方法,那么我們可以輕松的自動構造SQL語句了。

   但這樣做還是有欠靈活,因為一方面每一次使用該方法我們都得人工的設置table_name,col_x和value_x;另一方面別忘了sql語句中對于字符串的字段需要加單引號和替換字符串中間的單引號,而整型、浮點型、系統函數(如now(),to_date()等數據庫函數)等不需要做單引號的處理,這些假如沒有好的解決的話,我們的方法將受到非常大的限制。要達到再進一步分離最好的辦法就是在表單元素命名上面做文章,我們可以自己定義一套元素命名規則,對不同規則命名的元素做不同的處理--設我們定義元素命名規格如下:

   1. table_name,col_x,value_x這類元素,為公共元素。我們規定這類元素名以c_k開頭(c=common),我們限制table_name的元素名為c_table,col_x=value_x定義到一起,元素名定為c_where. 當然我們別忘了我們還需要一個元素表示構造什么樣(INSERT、DELETE、UPDATE)的SQL語句。我們給這個元素命名c_genre,它的值被限制在INSERT、DELETE、UPDATE這三者之中 。

   2. 對于表單中對應數據庫字符串類型的元素,在SQL構造中需要做單引號的處理。這類元素我們暫且稱他們為字符串型元素。字符串型元素我們規定其名為s_+數據庫表字段名 (s=String)。

   3. 對于不需要做但引號處理的元素(如integer型、float型、數據庫系統函數--如now(),to_date()等等)。我們暫且簡單的統稱這類元素為整型元素。對于整型元素我們限制其命名規則為i_+數據庫表字段名(i=Integer)。

   基于上面的規格我們可以非常輕松寫一個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里面來處理,且不是很爽?

   當然,這樣做的缺點也是有的。那就是有一定的性能損耗。非凡是碰到表單元素非常多時。但是我想對于那些不是很"苛刻"的項目這點損耗是值得的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久夜色精品国产| 91九色国产在线| 成人av在线天堂| 国产成人鲁鲁免费视频a| 日韩在线欧美在线国产在线| 深夜精品寂寞黄网站在线观看| 国产精品久久久久久久久粉嫩av| 中文字幕亚洲欧美日韩在线不卡| 国内自拍欧美激情| 欧美精品在线播放| 成人久久精品视频| 性欧美长视频免费观看不卡| 国产97在线视频| 一区二区三区www| 欧美性xxxxhd| 日韩免费av在线| 久久国产精品久久精品| 夜夜嗨av色综合久久久综合网| 91精品国产综合久久久久久蜜臀| 精品一区二区三区三区| 5566日本婷婷色中文字幕97| 欧美精品videossex88| 久久97精品久久久久久久不卡| 久久亚洲成人精品| 97国产suv精品一区二区62| 日本精品性网站在线观看| 国产91|九色| 欧美在线免费观看| 日韩精品免费在线| 午夜精品在线观看| 日韩av电影手机在线观看| 日韩av在线影视| 国内精品国产三级国产在线专| 91国在线精品国内播放| 久久99热精品| 日韩美女在线观看一区| www.xxxx欧美| 日韩av大片免费看| 国产精品一区二区久久| 国产精品情侣自拍| 精品亚洲夜色av98在线观看| 日韩国产欧美精品在线| 日韩激情av在线免费观看| 日本sm极度另类视频| 91精品国产成人www| 91成人在线观看国产| 4438全国亚洲精品在线观看视频| 国产一区二区三区视频在线观看| 好吊成人免视频| 国产一区二区三区四区福利| 国产精品一区二区av影院萌芽| 亚洲女在线观看| 国产精品亚洲综合天堂夜夜| 国产精品高潮呻吟久久av黑人| 久久久久久999| 欧美精品电影免费在线观看| 日韩欧美中文字幕在线播放| 亚洲精品成人久久久| 91精品中国老女人| 欧美在线视频在线播放完整版免费观看| 5566成人精品视频免费| 亚洲欧美日韩一区二区三区在线| 国产精品一区二区久久国产| 国产在线一区二区三区| 日本久久91av| 国产精品久久久久久久久影视| 少妇av一区二区三区| 国产欧美婷婷中文| 97色在线观看免费视频| 亚洲第一综合天堂另类专| 韩国视频理论视频久久| 97超级碰碰碰久久久| 亚洲美女免费精品视频在线观看| 亚洲最大成人免费视频| 午夜精品蜜臀一区二区三区免费| 在线精品视频视频中文字幕| 欧美激情a在线| 国产91色在线| 国产精品久久9| 国产丝袜一区二区| 中文字幕日韩在线播放| 亚洲91精品在线观看| 国产精品免费一区二区三区都可以| 亚洲女同精品视频| 欧美性xxxxx极品娇小| 日韩电影免费观看中文字幕| 中文字幕国产精品| 日韩精品在线免费播放| 日韩久久免费电影| 一区二区三区 在线观看视| 久久这里只有精品视频首页| 色老头一区二区三区在线观看| 永久免费看mv网站入口亚洲| 国产欧美一区二区三区四区| 欧美精品18videos性欧| 日韩风俗一区 二区| 国产精品欧美久久久| 欧美一区视频在线| 亚洲性生活视频在线观看| 国产精品成熟老女人| 日韩经典第一页| 亚洲国内高清视频| 日韩**中文字幕毛片| 日韩av影片在线观看| 国产视频亚洲视频| 中文字幕亚洲欧美在线| 超碰97人人做人人爱少妇| 成人网欧美在线视频| www.欧美精品一二三区| 亚洲男子天堂网| 久久久久久九九九| 欧美激情a在线| 在线色欧美三级视频| 一二美女精品欧洲| 国产精品久久网| 精品久久久国产| 欧美老女人性生活| 黄色成人在线免费| 精品无人区太爽高潮在线播放| 日韩在线免费视频| 欧美国产日本在线| 视频在线观看99| 精品国产欧美一区二区五十路| 久久久在线视频| 国产美女被下药99| 日韩影视在线观看| 久久精品视频在线播放| 国产视频999| 国产精品久久精品| 国产精品扒开腿爽爽爽视频| 欧美丰满老妇厨房牲生活| xvideos成人免费中文版| 大桥未久av一区二区三区| 欧美在线视频一区二区| 福利一区福利二区微拍刺激| 欧美大片在线免费观看| 永久免费毛片在线播放不卡| 亚洲国产成人精品久久久国产成人一区| 美女啪啪无遮挡免费久久网站| 一本色道久久88精品综合| 亚洲自拍偷拍福利| 日本精品一区二区三区在线| 亚洲一区二区久久久| 69精品小视频| 国产欧美精品在线播放| 日本一欧美一欧美一亚洲视频| 在线日韩日本国产亚洲| 亚洲最新在线视频| 国产精品嫩草视频| 精品中文字幕在线| 日本久久久久久久久| 欧美激情精品久久久久久久变态| 欧美在线一级va免费观看| 美女av一区二区| 亚洲精品电影在线| 精品国产999| 日韩福利在线播放| 久久视频精品在线| 亚洲区免费影片| 国产亚洲精品美女久久久久| 午夜精品福利视频| 成人xxxxx| 青青久久av北条麻妃海外网| 亚洲女人被黑人巨大进入|