日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
J2EE應(yīng)用程序中使用JavaBean實(shí)現(xiàn)SQL語句構(gòu)造

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

創(chuàng)新互聯(lián)是一家朝氣蓬勃的網(wǎng)站建設(shè)公司。公司專注于為企業(yè)提供信息化建設(shè)解決方案。從事網(wǎng)站開發(fā),網(wǎng)站制作,網(wǎng)站設(shè)計(jì),網(wǎng)站模板,微信公眾號(hào)開發(fā),軟件開發(fā),小程序設(shè)計(jì),10余年建站對(duì)砂巖浮雕等多個(gè)領(lǐng)域,擁有豐富的網(wǎng)站維護(hù)經(jīng)驗(yàn)。

 
 
 
  1. INSERT INTO table_name (col_1,col_2,col_3,) VALUES (value_1,value_2,value_3 …)  
  2. DELETE FROM table_name WHERE col_n=value_n  
  3. 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)方法可以獲取該元素的值。假設(shè)在開發(fā)中我們讓頁面元素的名稱和底層數(shù)據(jù)庫表的字段名一致。那么在這三種語句中col_n 和 value_n 對(duì)我們來說就不是未知的,未知的數(shù)據(jù)就剩下了 table_name,col_x和value_x ?,F(xiàn)在如果我們寫一個(gè)方法,傳入request對(duì)象,再把table_name,col_x,value_x作為參數(shù)傳入方法,那么我們可以輕松的自動(dòng)構(gòu)造SQL語句了。

但這樣做還是有欠靈活,因?yàn)橐环矫婷恳淮问褂迷摲椒ㄎ覀兌嫉萌斯さ脑O(shè)置table_name,col_x和value_x;另一方面別忘了sql語句中對(duì)于字符串的字段需要加單引號(hào)和替換字符串中間的單引號(hào),而整型、浮點(diǎn)型、系統(tǒng)函數(shù)(如now(),to_date()等數(shù)據(jù)庫函數(shù))等不需要做單引號(hào)的處理,這些如果沒有好的解決的話,我們的方法將受到非常大的限制。要達(dá)到再進(jìn)一步分離最好的辦法就是在表單元素命名上面做文章,我們可以自己定義一套元素命名規(guī)則,對(duì)不同規(guī)則命名的元素做不同的處理--設(shè)我們定義元素命名規(guī)格如下:

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

2. 對(duì)于表單中對(duì)應(yīng)數(shù)據(jù)庫字符串類型的元素,在SQL構(gòu)造中需要做單引號(hào)的處理。這類元素我們暫且稱他們?yōu)樽址驮?。字符串型元素我們?guī)定其名為s_+數(shù)據(jù)庫表字段名 (s=String)。

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

基于上面的規(guī)格我們可以非常輕松寫一個(gè)javabean。代碼如下:

 
 
 
  1. /**  
  2. * @version: 1.1  
  3. * @Time: 2005.03.02  
  4. */ 
  5. package com.river.page ;  
  6. import java.util.*;  
  7. import javax.servlet.http.HttpServletRequest;  
  8. public class PageUtil {  
  9.  private HttpServletRequest request = null ;  
  10.  public PageUtil(){}  
  11.  public void init(HttpServletRequest _request){  
  12.   this.request = _request ;  
  13.  }  
  14.  public void clear(){  
  15.   if(this.request != null){  
  16.   this.request = null ;  
  17.  }  
  18. }  
  19. public String get(String elementName){  
  20.  if(request == null || request.getParameter(elementName) == null){  
  21.   return "";  
  22.  }else{  
  23.   return request.getParameter(elementName);  
  24.  }  
  25. }  
  26. public String get(HttpServletRequest _request,String elementName){  
  27.  init(_request);  
  28.  return get(elementName);  
  29. }  
  30. public String getSQL(HttpServletRequest _request){  
  31.  init(_request);  
  32.  return getSQL();  
  33. }  
  34. public String getSQL(){  
  35.  String sqlstr = "";  
  36.  String c_table = get("c_table");  
  37.  String c_genre = get("c_genre");  
  38.  String c_where = get("c_where");  
  39.  if(c_genre == null || c_genre.equals("")){  
  40.   return "the action is null/empty";  
  41.  }  
  42.  if(c_table == null || c_table.equals("")){  
  43.   return "unknow table/empty" ;  
  44.  }  
  45.  if(c_genre.equalsIgnoreCase("INSERT")){  
  46.   java.util.Enumeration arg_names = request.getParameterNames();  
  47.   String colstr = "",valstr = "";  
  48.   String arg_name,pre_name,end_name ;  
  49.   while(arg_names.hasMoreElements()){  
  50.    arg_name = String.valueOf(arg_names.nextElement());  
  51.    if(arg_name.length() <2){  
  52.     continue;  
  53.    }  
  54.    pre_name = arg_name.substring(0,2);  
  55.    end_name = arg_name.substring(2);  
  56.    if(pre_name.equalsIgnoreCase("i_")){  
  57.     colstr = colstr+","+end_name;  
  58.     if(get(arg_name).equals("")){  
  59.      valstr = valstr+",NULL";  
  60.     }else{  
  61.      valstr = valstr + "," + String.valueOf(get(arg_name));  
  62.     }  
  63.    }else if(pre_name.equalsIgnoreCase("s_")){  
  64.     colstr = colstr+","+end_name;  
  65.     if(get(arg_name).equals("")){  
  66.      valstr = valstr+",NULL";  
  67.     }else{  
  68.      valstr = valstr+",’"+get(arg_name).replaceAll("’","’’")+"’";  
  69.    }  
  70.   }  
  71.  }  
  72.  if(!colstr.equals("")){  
  73.   colstr = colstr.substring(1);  
  74.   valstr = valstr.substring(1);  
  75.  }  
  76.  sqlstr = "INSERT INTO "+c_table+" ("+colstr+") VALUES ("+valstr+")";  
  77.  return sqlstr;  
  78. }else if(c_genre.equalsIgnoreCase("UPDATE")){  
  79.  java.util.Enumeration arg_names = request.getParameterNames();  
  80.  String colstr = "";  
  81.  String arg_name,pre_name,end_name ;  
  82.  while(arg_names.hasMoreElements()){  
  83.   arg_name = String.valueOf(arg_names.nextElement()).trim();  
  84.   if(arg_name.length() <2){  
  85.    continue;  
  86.   }  
  87.   pre_name = arg_name.substring(0,2);  
  88.   end_name = arg_name.substring(2);  
  89.   if(pre_name.equalsIgnoreCase("i_")){  
  90.    if(get(arg_name).equals("")){  
  91.     colstr += ","+end_name+"=NULL";  
  92.    }else{  
  93.     colstr += ","+end_name+"="+get(arg_name);  
  94.   }  
  95.  }else if(pre_name.equalsIgnoreCase("s_")){  
  96.   if(get(arg_name).equals("")){  
  97.    colstr += ","+end_name+"="+get(arg_name);  
  98.   }else{  
  99.    colstr += ","+end_name+"=’"+get(arg_name).replaceAll("’","’’")+"’";  
  100.   }  
  101.  }  
  102. }  
  103. if(!colstr.equals("")){  
  104.  colstr = colstr.substring(1);  
  105. }  
  106. sqlstr = "UPDATE "+c_table+" SET "+colstr;  
  107. if(!c_where.equals("")){  
  108.  sqlstr += " WHERE "+c_where;  
  109. }  
  110. return sqlstr;  
  111. }else if(c_genre.equalsIgnoreCase("DELETE")){  
  112. sqlstr = "DELETE FROM "+c_table;  
  113. if(c_where != null &&!c_where.equals("")){  
  114.  sqlstr += " WHERE "+c_where;  
  115. }  
  116. }else{  
  117.  com.river.debug.Debug.show("unknow action type : "+c_genre);  
  118.  return null;  
  119. }  
  120. return sqlstr;  
  121. }  
  122. public String toString(){  
  123.  return "version 1.0, date 2005.03.02, author river";  
  124. }  
  125. }  

這樣我們就可以根據(jù)頁面元素的命名來指導(dǎo)SQL語句的構(gòu)造。這樣做有很多的明顯的好處:

1. 減少編碼工作,對(duì)于元素很多表單,用不著我們?nèi)懸淮蠖训拇a,不用去擔(dān)心哪個(gè)元素落下了,元素名有沒有些錯(cuò),單引號(hào)有沒有處理。

2. 通用、穩(wěn)定、易于維護(hù),javabean固有的優(yōu)點(diǎn),就不用太多的說明了。

3. 分離表層的表單內(nèi)容與邏輯層SQL語句的構(gòu)造。設(shè)想一下,如果我們數(shù)據(jù)庫表結(jié)構(gòu)有調(diào)整時(shí),那么我們只要修改一下表單就好了,根本就不用理原來寫好的邏輯處理。附帶著再說一句,設(shè)想如果我們?cè)賹懸粋€(gè)類自動(dòng)執(zhí)行SQL,那么對(duì)于一些基本的增、刪、改操作都可以映射到同一個(gè)action里面來處理,且不是很爽?

當(dāng)然,這樣做的缺點(diǎn)也是有的。那就是有一定的性能損耗。特別是碰到表單元素非常多時(shí)。但是我想對(duì)于那些不是很"苛刻"的項(xiàng)目這點(diǎn)損耗是值得的。


本文題目:J2EE應(yīng)用程序中使用JavaBean實(shí)現(xiàn)SQL語句構(gòu)造
文章源于:http://m.5511xx.com/article/dpipcdo.html