亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? multidboperator.java

?? 哈工大cerp系統代碼
?? JAVA
字號:
package com.huiton.cerp.pub.util;

/**
 * Title:        WorkFlowSubsystem
 * Description:  工作流子系統相關類包
 * Copyright:    Copyright (c) 2001
 * Company:      BRITC
 * @author 高云鵬
 * @version 1.0
 */
import java.sql.*;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpServletRequest;
import java.util.Vector;
import com.huiton.pub.dbx.JdbOp;
import com.huiton.pub.dbx.PageQuery;
import com.huiton.cerp.pub.util.WebKeys;
import com.huiton.cerp.pub.util.SubsystemKeys;
import com.huiton.cerp.pub.util.DBOperators;
import com.huiton.mainframe.util.tracer.Debug;

public class MultiDBOperator {


static private JdbOp jdbOp;
static private PageQuery pageQuery;
static private String mainDB;
static private String attachDB;
static private String tablenameMain;
static private String tablenameAttached;
static private String funcCode;
static private String sessioncode;
static private HttpServletRequest request;

static private int pageCount;
/*public MultiDBOperator( HttpServletRequest request,String mainDB,
                         String attachDB,String sessioncode,String funcCode){

                          jdbOp=getJdbOp(request,sessionCode,mainDB);
                          pageQuery=getPageQuery(request,sessionCode,mainDB,funcCode);
                         }*/
public MultiDBOperator(String mainDB,
                        String attachDB,
                        String tablenameMain,
                        String tablenameAttached,
                        String funcCode,
                        String sessioncode,
                        HttpServletRequest request)
                  throws Exception{
                          this.mainDB=mainDB;
                          this.attachDB=attachDB;
                          this.tablenameMain=tablenameMain;
                          this.tablenameAttached=tablenameAttached;
                          this.funcCode=funcCode;
                          this.sessioncode=sessioncode;
                          this.request=request;
                          this.pageQuery=DBOperators.getPageQuery(request,sessioncode,mainDB,funcCode);
                          this.jdbOp=jdbOp=DBOperators.getJdbOp(request,sessioncode,attachDB);
                          }




/*@@說明
    本方法有一定局限性,不是通用方法,須完善。
    適合于:對兩個表的查詢,其中的一個表中的某個字段為特定值時,另外一個表中有元組與之對應,須取出該元組中的某些字段
    局限:第二個表中的關鍵字為一個
         第二個表中的關鍵字為字串
    @@param:mainDB--主子系統名
            attachDB--副子系統名
            tablenameMain--主表名
            tablenameAttached--副表名
            keyWord--主表中特定字段昭示附表中有對應元組時的值
            keyFieldLocation--特定字段在取出的Vector中數組中的序號
            pagesize--取1頁的長度
            offset--無附表元組時返回數組的填充值
            mainSQL--主表查詢條件
            mainFields--主表字段:須在第一個字段中設置與附表的聯系鍵值
            mainNo--主表字段數
            attachFields--附表字段:須在第一個字段中設置與主表的聯系鍵值,該值不在最后的vector-row中出現
            attachNo--附表字段數
            currentpage--當前頁
            */
public Vector multiDBDividePage(String keyWord,
                                      int keyFieldLocation,
                                      int pagesize,
                                         String offset,
                                         String mainSQL,
                                         String[] mainFields,
                                         String[] attachFields,
                                      int currentpage)
                                       throws SQLException, Exception{
                    Debug.println("multiDBOperator:參數帶來的currentPage為:"+currentpage);
                    Debug.println("multiDBOperator:mainSQL為:"+mainSQL);
                    jdbOp=DBOperators.getJdbOp(request,sessioncode,attachDB);
                    pageQuery=DBOperators.getPageQuery(request,sessioncode,mainDB,funcCode);
                    Debug.println("multiDBOperator:獲得主、副數據庫代理......");

                  int mainNo=mainFields.length;
                  int attachNo=attachFields.length;
                    //獲取第一個表中的相關字段結果集
                    String fields=mainFields[0];
                    for(int i=1;i<mainNo;i++)
                                                fields+=","+mainFields[i];
                    Debug.println("multiDBOperator:主數據庫字段為:"+fields);
                    Debug.println("multiDBOperator:table為:"+tablenameMain);
                    Debug.println("multiDBOperator:獲得主數據庫參數為:"+mainDB);
                    Debug.println("multiDBOperator:主數據庫名為:"+pageQuery.m_conn.getCatalog());
                    pageQuery.getData(fields,tablenameMain,mainSQL,pagesize);

                   this.pageCount=pageQuery.pageCount;
                    Debug.println("multiDBOperator:pagecount為:"+pageCount);
                    Debug.println("multiDBOperator:pageQuery取數據完成......");
                  if(currentpage<=0)currentpage=1;
                    Debug.println("multiDBOperator:當前頁為:"+currentpage);
                    Vector mainVCT=pageQuery.dividePage(currentpage,pagesize);
                   if(mainVCT==null){
                              Debug.println("multiDBOperator:無記錄,返回空......");
                            return null;
                    }
                    Debug.println("multiDBOperator:pageQuery分頁完成......");
                    Debug.println("multiDBOperator:pageQuery元素數為:"+String.valueOf(mainVCT.size()));

                    //處理與第二個表的關聯
                    fields=attachFields[0];
                    Vector ultimateVCT=new Vector();
                  for(int i=1;i<attachNo;i++)
                                                fields+=","+attachFields[i];
                    Debug.println("multiDBOperator:副數據庫字段為:"+fields);

                    for(int i=0;i<mainVCT.size();++i){
                            String VCTArray[]=new String[mainNo+attachNo-1];
                            String tmpVCTArray[]=new String[mainNo];
                            Debug.println("----MultiDBOperator:mainNo="+mainNo+"attachNo="+attachNo);
                            tmpVCTArray = (String[])mainVCT.elementAt(i);
                            Debug.println("----MultiDBOperator:從Vector 中取得第"+i+"個數組");
                          for(int j=0;j<mainNo;j++){
                                           VCTArray[j]=tmpVCTArray[j];
                                           Debug.println("multiDBOperator:主數據庫中的數組元素["+j+"]為:"+VCTArray[j]);
                                          }
                          if(VCTArray[keyFieldLocation].toLowerCase().equals(keyWord)){
                                         String attachSQL="select "+fields+" from "+tablenameAttached+" where "
                                                        +attachFields[0]+"='"+VCTArray[0]+"'";
                                         Debug.println("multiDBOperator:副數據庫查詢SQL為:"+attachSQL);
                                         ResultSet rs=jdbOp.getData(attachSQL);
                                          Debug.println("multiDBOperator:取得副數據庫結果集......");
                                   //   int appendLengh=attachFields.length;
                                         if(rs!=null){
                                                  rs.beforeFirst();
                                               if(rs.next()){
                                                       // String[] appendArray=new String[appendLength];
                                                    for(int j=1;j<attachNo;j++){
                                                                VCTArray[mainNo+j-1]=rs.getString(j+1);
                                                                Debug.println("multiDBOperator:副數據庫中的數組元素["+j+"]為:"+VCTArray[mainNo+j-1]);
                                                                }
                                                    }else{
                                                    for(int j=0;j<attachNo-1;j++)
                                                                  VCTArray[mainNo+j]=offset;
                                                        Debug.println("multiDBOperator:填充1");
                                                          }
                                              }else{
                                               for(int j=0;j<attachNo-1;j++)
                                                        VCTArray[mainNo+j]=offset;
                                                   Debug.println("multiDBOperator:填充2");
                                                    }
                             }else{
                                       for(int j=0;j<attachNo-1;j++)
                                                        VCTArray[mainNo+j]=offset;
                                          Debug.println("multiDBOperator:填充3");
                              }
                              ultimateVCT.addElement(VCTArray);
                              Debug.println("multiDBOperator:即一個數組到最終返回的矢量中......");
                        }
                            return ultimateVCT;
                }

public int getPageCount()
                  {
                          return this.pageCount;
         }

public void multiDBDelete(String mainFlagField,
                            String keyWord,
                            String mainField,
                            String attachField,
                            String delSQL)
                          throws SQLException, Exception{
              Debug.println("multiDBOperator:delSQL為:"+delSQL);
              jdbOp=DBOperators.getJdbOp(request,sessioncode,mainDB);
              Debug.println("multiDBOperator:獲取住數據庫代理:"+mainDB);
              String tempSQL="select "+mainFlagField+","+mainField+" from "+tablenameMain+" where "+delSQL;
              Debug.println("multiDBOperator:tempSQL為:"+tempSQL);
              ResultSet rs=jdbOp.getData(tempSQL);
              Debug.println("multiDBOperator:查得主數據庫數據......");
              int mainFlagFieldColNo;
              int mainFiledColNo;
              mainFlagFieldColNo=rs.findColumn(mainFlagField);
              mainFiledColNo=rs.findColumn(mainField);
              if(rs!=null){
                      Debug.println("multiDBOperator:結果集不為空......");
                      rs.beforeFirst();
                    while(rs.next()){
                          String mainFlagValue=rs.getString(mainFlagFieldColNo);
                          String mainValue=rs.getString(mainFiledColNo);
                          Debug.println("multiDBOperator:主數據庫標示--"+mainFlagValue);
                          Debug.println("multiDBOperator:主數據庫連接字段值--"+mainValue);
                          if(mainFlagValue.equals(keyWord)){
                                  tempSQL=attachField+"="+mainValue;
                                  Debug.println("multiDBOperator:有對應元組---SQL為:"+tempSQL);
                                  jdbOp=DBOperators.getJdbOp(request,sessioncode,attachDB);
                                  jdbOp.delete(tablenameAttached,tempSQL);
                                  Debug.println("multiDBOperator:副數據庫刪除一條元組");
                                  }
                        }
                }
              jdbOp=DBOperators.getJdbOp(request,sessioncode,mainDB);
              jdbOp.delete(tablenameMain,delSQL);
              Debug.println("multiDBOperator:主數據庫刪除完成");
        return;

        }

public PageQuery getPageQuery(){
        return this.pageQuery;
    }

public JdbOp getJdbOp(){
        return this.jdbOp;
    }
}
 /*                   pageQuery.getData("USER_NAME,USER_UNIQUE_NO",
                                      "EPD_ADDRESS_EMPLOYEE_V", mySQL, SLIT_Vct.size());

                    jdbOp=getJdbOp(request,sessioncode,dbnameMain);
                    pageQuery=getPageQuery(request,sessioncode,dbnameMain,funcCode);
                    Vector mainVCT





  /*private DBOperators dbOperator;
  private JdbOp jdbOp;
  private PageQuery pageQuery;

  public MultiDBOperator() {
        this.dbOperator=new DBOperators();
  }

  public MultiDBOperator(String mainDB,String attachDB,sessioncode, funcCode) {
          this.dbOperator=new DBOperators();

  public JdbOp getJdbOp(HttpServletRequest request,
                          String sessionCode,
                          String subsystemKey){
        JdbOp tempJdbOp=dbOperator.getJdbOp(request,sessioncode,subsystemKey);
        this.jdbOp=tempJdbOp;
        return tempJdbOp;
  }

  public getPageQuery(HttpServletRequest request,
                        String sessionCode,
                        String subsystemKey,
                        String funcCode){
        PageQuery tempPageQuery=dbOperator.getPageQuery(request,sessioncode,subsystemKey,funcCode);
        this.pageQuery=tempPageQuery;
        return tempPageQuery;
  }
  /*用于將兩個數據庫聯起來查詢一頁
  param:

  public Vector multiDBDividePage(String dbnameMain,String dbnameAttached,String field,
                                    String keyword,int pagesize,String offset){
     Vector vct1=new Vector();
*/



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人黄色在线看| 国产呦精品一区二区三区网站| 欧美性欧美巨大黑白大战| 欧美国产一区在线| 91久久国产最好的精华液| 奇米色777欧美一区二区| 日韩欧美高清dvd碟片| 不卡的电影网站| 图片区小说区区亚洲影院| 久久久久久久国产精品影院| 一本色道综合亚洲| 精品一区二区三区日韩| 国产精品嫩草久久久久| 在线免费观看日本一区| 日韩在线一区二区| 中文子幕无线码一区tr| 欧美久久久久久久久中文字幕| 国产乱码精品一区二区三区忘忧草| 亚洲精品久久久久久国产精华液| 精品久久久久一区| 欧美三区在线观看| 成人丝袜18视频在线观看| 亚洲日本va在线观看| 久久久精品国产免大香伊| 欧美三片在线视频观看 | 一区二区三国产精华液| 日韩色视频在线观看| 91老师片黄在线观看| 日本女人一区二区三区| 亚洲黄色av一区| 国产欧美一区二区三区在线老狼| 色综合网色综合| 奇米四色…亚洲| 伊人一区二区三区| 国产精品系列在线| 久久亚洲捆绑美女| 91精品国产黑色紧身裤美女| www.成人在线| 国产成人综合在线播放| 免费看欧美女人艹b| 亚洲一级片在线观看| 久久综合九色综合97婷婷女人 | 久久久精品tv| 日韩欧美中文字幕精品| 欧美日韩日日骚| 色婷婷综合久久久中文一区二区 | 日韩一二三区视频| 91国内精品野花午夜精品 | 欧美色图12p| 91视频www| thepron国产精品| av电影一区二区| 国产自产高清不卡| 卡一卡二国产精品| 免费久久精品视频| 日韩精品一级中文字幕精品视频免费观看 | 欧美一个色资源| 777奇米成人网| 欧美久久婷婷综合色| 欧美日韩免费电影| 欧美图区在线视频| 欧美视频你懂的| 欧美日韩精品专区| 欧美丰满少妇xxxxx高潮对白| 欧美日韩精品是欧美日韩精品| 91麻豆福利精品推荐| 91亚洲精品久久久蜜桃网站| 一本一道波多野结衣一区二区| 色噜噜狠狠成人中文综合| 一本久久精品一区二区| 国产亚洲欧美一级| 久久精品视频免费观看| 日本一区二区三区视频视频| 最新日韩在线视频| 亚洲一区精品在线| 午夜精品久久久久久久蜜桃app| 亚洲福利视频三区| 日本成人在线视频网站| 理论片日本一区| 国产成人在线影院| 韩国欧美国产1区| 国产成人亚洲综合色影视| 99re热这里只有精品免费视频 | 日韩一区二区三区在线视频| 欧美日韩国产a| 日韩精品一区二区三区视频在线观看 | 国产在线播放一区| 成人蜜臀av电影| 欧美视频在线一区| 欧美精品一区二区三区高清aⅴ | 日韩福利视频导航| 韩国一区二区三区| 99免费精品视频| 欧美日本在线一区| 精品国产不卡一区二区三区| 亚洲精品一区二区三区精华液| 国产精品久线在线观看| 五月综合激情婷婷六月色窝| 激情综合色播激情啊| 成人免费视频网站在线观看| 在线观看亚洲专区| 精品成人佐山爱一区二区| 国产欧美精品一区aⅴ影院| 一区二区三区在线观看视频| 美女国产一区二区| 中文字幕亚洲成人| 亚洲精品乱码久久久久久日本蜜臀 | 最好看的中文字幕久久| 一区二区三区在线免费观看 | 五月天欧美精品| 在线电影一区二区三区| 欧美肥妇毛茸茸| 欧美久久一二区| 欧美一卡二卡在线观看| 精品国精品国产| 国产欧美日韩久久| 国产欧美日韩不卡| 一区二区三区色| 日韩精品免费视频人成| 精品一区二区免费视频| 国产东北露脸精品视频| 91美女片黄在线观看| 欧美日韩精品欧美日韩精品一| 欧美人与性动xxxx| 精品国产一区二区三区四区四 | 久久99久久99小草精品免视看| 国产综合久久久久久久久久久久| 成人污污视频在线观看| 成人爱爱电影网址| 日本久久精品电影| 日韩三级中文字幕| 国产亚洲人成网站| 亚洲成人一区二区在线观看| 捆绑紧缚一区二区三区视频| 成人性色生活片| 日韩欧美你懂的| 亚洲国产一二三| 成人av午夜影院| 精品国产乱码久久| 日本不卡一二三区黄网| 色94色欧美sute亚洲线路一ni| xf在线a精品一区二区视频网站| 亚洲国产欧美日韩另类综合| 波多野结衣中文字幕一区二区三区| 日韩欧美一区中文| 亚洲国产精品久久艾草纯爱| 色综合咪咪久久| 欧美激情在线观看视频免费| 麻豆精品在线看| 欧美一区二区三区婷婷月色| 一区二区三区在线影院| 99久久综合国产精品| 国产无遮挡一区二区三区毛片日本| 久久精品72免费观看| 欧美人与禽zozo性伦| 亚洲午夜私人影院| 91豆麻精品91久久久久久| 亚洲人xxxx| 成人av网站免费观看| 国产日韩影视精品| 国产乱一区二区| 精品国产免费视频| 韩国女主播一区二区三区| 精品国产一区二区精华| 国产综合色在线| 久久精品夜夜夜夜久久| 国产精品亚洲视频| 中文字幕成人av| 成人污污视频在线观看| 日韩理论片中文av| 91视频国产资源| 一区二区三区加勒比av| 在线视频国内自拍亚洲视频| 亚洲国产一区视频| 69堂国产成人免费视频| 麻豆精品国产91久久久久久| 精品欧美一区二区久久| 狠狠色狠狠色综合系列| 国产亚洲欧洲997久久综合| 成人av在线网站| 亚洲乱码国产乱码精品精的特点| 欧美性欧美巨大黑白大战| 偷拍一区二区三区| 欧美一区二区不卡视频| 国产精品自拍在线| 中文字幕一区二区三区四区不卡| 91麻豆免费看片| 亚洲在线视频一区| 欧美一区二区三区精品| 国产精品1区2区3区| 亚洲女同ⅹxx女同tv| 欧美这里有精品| 日本最新不卡在线| 国产亚洲综合性久久久影院| 91片在线免费观看| 蜜臀av亚洲一区中文字幕| 久久精品一区八戒影视| 欧美在线观看一二区| 免费人成在线不卡| 国产精品国产馆在线真实露脸|