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

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

?? multidboperator.java

?? 哈工大CERP系統 java+weblogic實現
?? 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| 成人app软件下载大全免费| 欧美日韩视频在线观看一区二区三区| 91精品国产综合久久香蕉的特点| 国产精品国产三级国产| 精品一区二区三区在线观看国产| 在线观看不卡一区| 国产精品网站导航| 国产一区二区免费视频| 日韩一区二区三区电影在线观看 | 色域天天综合网| 精品免费一区二区三区| 视频一区欧美精品| 欧美亚洲国产一区二区三区| 国产精品久久久久一区二区三区共| 青青草国产成人av片免费| 欧美综合一区二区三区| 亚洲精选一二三| av亚洲精华国产精华| 国产色婷婷亚洲99精品小说| 久久精品久久99精品久久| 欧美日韩日日摸| 亚洲精品乱码久久久久久久久| 国产很黄免费观看久久| 久久久久亚洲蜜桃| 久草热8精品视频在线观看| 精品视频在线免费看| 亚洲一区二区在线视频| 在线一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲综合成人在线视频| 成人久久视频在线观看| 国产日韩欧美在线一区| 国产成人在线观看免费网站| 久久亚洲捆绑美女| 国产99精品国产| 国产精品免费看片| 99精品视频在线观看| 亚洲欧洲性图库| 91蜜桃网址入口| 亚洲精品成人a在线观看| 色素色在线综合| 亚洲1区2区3区视频| 精品久久久网站| 国产成人免费xxxxxxxx| 亚洲品质自拍视频网站| 欧美日韩精品欧美日韩精品一 | 亚洲国产精品v| av资源网一区| 亚洲动漫第一页| 91麻豆精品国产91久久久久久| 蜜桃一区二区三区四区| 久久久久综合网| 91久久精品午夜一区二区| 亚洲成人先锋电影| 久久久精品蜜桃| 色网站国产精品| 捆绑紧缚一区二区三区视频| 国产午夜精品在线观看| 在线看一区二区| 精品一区二区av| 亚洲黄网站在线观看| 日韩欧美国产三级| 风间由美一区二区三区在线观看 | 日本一区二区三区电影| 欧美性大战xxxxx久久久| 久久综合综合久久综合| 国产精品久线在线观看| 欧美一级黄色大片| 99国产精品久久久久久久久久久| 日韩精品高清不卡| 中文字幕在线一区免费| 日韩一区二区在线观看视频| 亚洲国产视频网站| 久久精品一区四区| 91精品国产色综合久久久蜜香臀| 成人综合在线网站| 国产精品麻豆欧美日韩ww| 欧美一区二区三区四区五区| 97久久超碰精品国产| 国产九九视频一区二区三区| 无码av免费一区二区三区试看 | 精品国产伦理网| 一本到不卡免费一区二区| 国产专区欧美精品| 亚洲电影第三页| 亚洲日本在线天堂| 中文字幕乱码久久午夜不卡| 欧美精品欧美精品系列| 色婷婷国产精品久久包臀| 国产在线精品一区在线观看麻豆| 亚洲国产成人va在线观看天堂 | 久久亚洲二区三区| 欧美人伦禁忌dvd放荡欲情| 色综合久久久久综合| 成人免费看视频| 国产精品香蕉一区二区三区| 日韩成人一级大片| 亚洲成人av一区二区三区| 亚洲天堂网中文字| 欧美极品aⅴ影院| 国产视频在线观看一区二区三区| 精品国产sm最大网站免费看| 欧美一区二区日韩| 欧美肥妇毛茸茸| 欧美日韩日日骚| 6080午夜不卡| 欧美猛男gaygay网站| 欧美日韩电影在线播放| 在线视频国内自拍亚洲视频| 欧美四级电影在线观看| 欧美日韩综合色| 91精品国产丝袜白色高跟鞋| 在线播放亚洲一区| 日韩午夜激情免费电影| 日韩你懂的电影在线观看| 2021国产精品久久精品| 久久午夜色播影院免费高清| 国产日韩精品一区| ...xxx性欧美| 亚洲国产一二三| 日韩专区中文字幕一区二区| 老司机午夜精品| 国产成人免费网站| 99v久久综合狠狠综合久久| 色综合色综合色综合色综合色综合 | 成人精品一区二区三区中文字幕| 国产不卡在线播放| 91婷婷韩国欧美一区二区| 欧美亚洲综合网| 欧美一区日本一区韩国一区| 久久一区二区三区国产精品| 欧美国产精品专区| 亚洲一区欧美一区| 久久超碰97人人做人人爱| 国产精品18久久久久| 91影院在线免费观看| 欧美日韩二区三区| 亚洲精品一区在线观看| 亚洲色图色小说| 日精品一区二区三区| 国产福利91精品一区二区三区| 色呦呦国产精品| 精品久久一区二区| 亚洲欧美日韩国产成人精品影院 | 成人午夜精品一区二区三区| 色综合一区二区三区| 日韩一二三区不卡| 国产精品久久久一区麻豆最新章节| 一区二区高清在线| 国产激情91久久精品导航| 欧美日韩在线直播| 欧美r级电影在线观看| 亚洲天堂2016| 国产一区二区三区综合| 91小视频在线| 久久天天做天天爱综合色| 亚洲尤物视频在线| 高清不卡在线观看| 精品免费99久久| 亚洲一区在线视频观看| 成人精品免费视频| 欧美成人艳星乳罩| 亚洲午夜电影在线| 成人三级在线视频| 亚洲精品在线电影| 天堂成人免费av电影一区| 国产乱色国产精品免费视频| 欧美丝袜自拍制服另类| 国产欧美精品国产国产专区| 日本成人在线看| 在线精品观看国产| 中文字幕一区二区在线播放| 久久精品国产亚洲高清剧情介绍 | 久久久不卡网国产精品二区| 天天综合天天做天天综合| 91丨porny丨首页| 国产清纯白嫩初高生在线观看91 | 99国产精品国产精品久久| 久久综合九色综合97婷婷 | 国产九九视频一区二区三区| 欧美一区二区三区影视| 亚洲制服欧美中文字幕中文字幕| 成人国产精品免费观看视频| 2023国产精品视频| 久久99国产精品麻豆| 在线不卡中文字幕播放| 亚洲线精品一区二区三区| 在线亚洲一区观看| 亚洲综合色自拍一区| 欧美在线免费播放| 亚洲一区二区三区视频在线播放 | 亚洲成人免费观看| 在线视频欧美精品| 亚洲自拍偷拍图区| 欧美性大战xxxxx久久久| 亚洲一区二区三区三| 在线精品视频免费播放| 亚洲最新视频在线观看|