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

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

J2EE基礎應用:J2EE中SQL語句自動構造方法

2019-11-17 04:34:08
字體:
來源:轉載
供稿:網友

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| 一本色道久久综合狠狠躁篇怎么玩| 久久久久亚洲精品| 欧美激情一区二区久久久| 亚洲国产高清福利视频| 国产精品一区二区三区免费视频| 成人激情av在线| 亚洲一区二区三区777| 国产在线不卡精品| 一区二区三区久久精品| 9.1国产丝袜在线观看| 欧美成人午夜剧场免费观看| 日本成人激情视频| 成人久久久久久久| 国产男女猛烈无遮挡91| 精品国产31久久久久久| 日韩精品一区二区三区第95| 欧美大全免费观看电视剧大泉洋| 欧美一级成年大片在线观看| 日韩电影网在线| 欧美日韩免费在线| 久久国产色av| 不卡毛片在线看| 成人性生交大片免费看小说| 97视频免费观看| 亚洲aⅴ男人的天堂在线观看| 亚洲国产精品va在线看黑人动漫| 国产噜噜噜噜噜久久久久久久久| 一本大道亚洲视频| 久久天天躁夜夜躁狠狠躁2022| 欧美野外猛男的大粗鳮| 欧美激情视频一区| 亚洲精品国产suv| 欧美日韩亚洲成人| 亚洲国产精久久久久久| 亚洲精品视频在线播放| 日韩精品在线观看网站| 亚洲深夜福利在线| 91牛牛免费视频| 国产精品影院在线观看| 日韩欧美国产一区二区| 亚洲女人被黑人巨大进入al| 久久99视频免费| 日韩一级裸体免费视频| 久久久久久久久久久网站| 日韩欧美中文第一页| 在线观看欧美www| 亚洲精品720p| 中文在线资源观看视频网站免费不卡| 国产精品男人爽免费视频1| 亚洲tv在线观看| 欧美黄色小视频| 中日韩美女免费视频网站在线观看| 亚洲香蕉成视频在线观看| 中文字幕av一区二区三区谷原希美| 亚洲国产精品久久久久秋霞蜜臀| 日韩成人网免费视频| 97在线视频一区| 免费97视频在线精品国自产拍| 成人激情视频在线播放| 久久影视三级福利片| 欧美激情手机在线视频| 91美女片黄在线观| 91热精品视频| 国产精品jvid在线观看蜜臀| 9.1国产丝袜在线观看| 亚洲精品福利免费在线观看| 国产成人综合精品在线| 美日韩在线视频| 欧美在线视频播放| www.久久撸.com| 欧美午夜视频在线观看| 日韩一区二区精品视频| 国产精品日日摸夜夜添夜夜av| 日韩毛片在线看| 久久中文精品视频| 亚洲欧美在线看| 亚洲欧美精品一区二区| 日韩精品视频在线免费观看| 午夜精品一区二区三区在线视| 91国产视频在线播放| 97视频在线观看亚洲| 性色av一区二区三区在线观看| 国产精品xxx视频| 久久久黄色av| 精品久久久一区| 日韩av网址在线观看| 欧美一乱一性一交一视频| 国产亚洲精品美女久久久| 久久国产色av| 久久九九精品99国产精品| 91精品在线影院| 国产一区二区日韩| 国产亚洲精品综合一区91| 欧美亚洲第一区| 国产精品精品久久久久久| 日本欧美精品在线| 在线观看欧美成人| 亚洲国产一区二区三区四区| 色综合色综合网色综合| 91福利视频在线观看| 欧美激情第三页| 国产香蕉精品视频一区二区三区| 91久久综合亚洲鲁鲁五月天| 国模吧一区二区三区| 日韩视频免费中文字幕| 国模叶桐国产精品一区| 九九热这里只有精品免费看| 精品欧美国产一区二区三区| 久久大大胆人体| 国产综合久久久久久| 亚洲欧美在线看| 日韩精品高清视频| 欧美第一页在线| 91色中文字幕| 日韩视频第一页| 国产精品青草久久久久福利99| 久久在线免费视频| 亚洲久久久久久久久久| 欧美日韩精品二区| 午夜精品一区二区三区在线播放| 91高清视频免费| 亚洲裸体xxxx| 亚洲成人激情小说| 久久久亚洲国产天美传媒修理工| 亚洲一区二区三区四区在线播放| 欧美性生活大片免费观看网址| 91精品国产色综合久久不卡98口| 亚洲综合日韩在线| 亚洲精品色婷婷福利天堂| 日韩亚洲在线观看| 青草青草久热精品视频在线观看| 国产精品爽爽爽爽爽爽在线观看| 91伊人影院在线播放| 97人人爽人人喊人人模波多| 亚洲精品一区二区网址| 欧美激情精品久久久久久| 欧美黄色免费网站| 亚洲福利小视频| 色妞欧美日韩在线| 久久久91精品| 日韩在线观看免费| 国产在线精品播放| 懂色aⅴ精品一区二区三区蜜月| 国产91在线高潮白浆在线观看| 国产精品老女人视频| 国产一区二区欧美日韩| 一区二区中文字幕| 亚洲精品国产精品国自产在线| 日韩欧美国产成人| 国产免费一区二区三区在线观看| 97超碰色婷婷| 亚洲色图国产精品| 色先锋资源久久综合5566| 91精品久久久久久久久久| 国产日韩欧美一二三区| 国产欧美日韩精品专区| 欧美日韩第一页| 久久夜色精品亚洲噜噜国产mv| 在线精品国产成人综合| 中文字幕久久久av一区|