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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? multidboperator.java

?? CERP系統(tǒng)
?? JAVA
字號:
package com.huiton.cerp.pub.util;

/**
 * Title:        WorkFlowSubsystem
 * Description:  工作流子系統(tǒng)相關(guān)類包
 * 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);
                          }




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

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

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

                    //處理與第二個表的關(guān)聯(lián)
                    fields=attachFields[0];
                    Vector ultimateVCT=new Vector();
                  for(int i=1;i<attachNo;i++)
                                                fields+=","+attachFields[i];
                    Debug.println("multiDBOperator:副數(shù)據(jù)庫字段為:"+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+"個數(shù)組");
                          for(int j=0;j<mainNo;j++){
                                           VCTArray[j]=tmpVCTArray[j];
                                           Debug.println("multiDBOperator:主數(shù)據(jù)庫中的數(shù)組元素["+j+"]為:"+VCTArray[j]);
                                          }
                          if(VCTArray[keyFieldLocation].toLowerCase().equals(keyWord)){
                                         String attachSQL="select "+fields+" from "+tablenameAttached+" where "
                                                        +attachFields[0]+"='"+VCTArray[0]+"'";
                                         Debug.println("multiDBOperator:副數(shù)據(jù)庫查詢SQL為:"+attachSQL);
                                         ResultSet rs=jdbOp.getData(attachSQL);
                                          Debug.println("multiDBOperator:取得副數(shù)據(jù)庫結(jié)果集......");
                                   //   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:副數(shù)據(jù)庫中的數(shù)組元素["+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:即一個數(shù)組到最終返回的矢量中......");
                        }
                            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:獲取住數(shù)據(jù)庫代理:"+mainDB);
              String tempSQL="select "+mainFlagField+","+mainField+" from "+tablenameMain+" where "+delSQL;
              Debug.println("multiDBOperator:tempSQL為:"+tempSQL);
              ResultSet rs=jdbOp.getData(tempSQL);
              Debug.println("multiDBOperator:查得主數(shù)據(jù)庫數(shù)據(jù)......");
              int mainFlagFieldColNo;
              int mainFiledColNo;
              mainFlagFieldColNo=rs.findColumn(mainFlagField);
              mainFiledColNo=rs.findColumn(mainField);
              if(rs!=null){
                      Debug.println("multiDBOperator:結(jié)果集不為空......");
                      rs.beforeFirst();
                    while(rs.next()){
                          String mainFlagValue=rs.getString(mainFlagFieldColNo);
                          String mainValue=rs.getString(mainFiledColNo);
                          Debug.println("multiDBOperator:主數(shù)據(jù)庫標(biāo)示--"+mainFlagValue);
                          Debug.println("multiDBOperator:主數(shù)據(jù)庫連接字段值--"+mainValue);
                          if(mainFlagValue.equals(keyWord)){
                                  tempSQL=attachField+"="+mainValue;
                                  Debug.println("multiDBOperator:有對應(yīng)元組---SQL為:"+tempSQL);
                                  jdbOp=DBOperators.getJdbOp(request,sessioncode,attachDB);
                                  jdbOp.delete(tablenameAttached,tempSQL);
                                  Debug.println("multiDBOperator:副數(shù)據(jù)庫刪除一條元組");
                                  }
                        }
                }
              jdbOp=DBOperators.getJdbOp(request,sessioncode,mainDB);
              jdbOp.delete(tablenameMain,delSQL);
              Debug.println("multiDBOperator:主數(shù)據(jù)庫刪除完成");
        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;
  }
  /*用于將兩個數(shù)據(jù)庫聯(lián)起來查詢一頁
  param:

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



?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产在线不卡视频| 在线观看av一区| 亚洲夂夂婷婷色拍ww47| 欧美精品一区二区高清在线观看| 不卡大黄网站免费看| 蜜桃一区二区三区四区| 亚洲综合另类小说| 欧美精品一区二区三区视频| 欧美午夜精品电影| av亚洲精华国产精华精华| 久久精品二区亚洲w码| 一区二区高清免费观看影视大全| 久久婷婷成人综合色| 欧美日韩精品系列| 在线中文字幕不卡| 99久久精品费精品国产一区二区 | 午夜视频一区在线观看| 国产精品每日更新在线播放网址| 日韩精品一区二区三区老鸭窝| 欧美在线看片a免费观看| 成人一级片在线观看| 国内精品伊人久久久久av一坑| 亚瑟在线精品视频| 亚洲最快最全在线视频| 日韩毛片视频在线看| 国产欧美视频一区二区| 国产日韩三级在线| 久久久久青草大香线综合精品| 日韩一区二区三区av| 欧美精品日日鲁夜夜添| 欧美日韩的一区二区| 在线一区二区三区做爰视频网站| aaa欧美色吧激情视频| 99久久综合狠狠综合久久| 成人涩涩免费视频| 岛国一区二区在线观看| 国产成人精品免费视频网站| 国产a精品视频| 高清成人在线观看| 国产aⅴ综合色| 成人激情综合网站| www.欧美日韩| 91色视频在线| 在线欧美小视频| 欧美四级电影网| 欧美色网站导航| 欧美丰满少妇xxxxx高潮对白| 欧美日本韩国一区| 欧美一级专区免费大片| 精品福利在线导航| 国产三级三级三级精品8ⅰ区| 国产女人18水真多18精品一级做| 国产人成一区二区三区影院| 国产精品丝袜久久久久久app| 亚洲欧美综合色| 亚洲最大成人综合| 日韩精品亚洲一区| 韩国女主播成人在线观看| 国产精品一区二区不卡| 99re这里只有精品视频首页| 色av成人天堂桃色av| 欧美日韩高清一区| 精品福利av导航| 国产精品素人一区二区| 亚洲午夜一区二区| 久久精品国产亚洲a| 成人永久看片免费视频天堂| 一本久道久久综合中文字幕 | 一区二区三区在线视频播放| 亚洲最大成人网4388xx| 久久精品99国产国产精| 成人免费毛片片v| 欧美三级日韩三级国产三级| 欧美电影免费提供在线观看| 国产精品国产三级国产aⅴ无密码| 一区二区在线观看av| 九九视频精品免费| av一区二区久久| 日韩一区二区三区在线视频| 久久久综合九色合综国产精品| 亚洲欧美另类小说视频| 久久国产三级精品| 99久久er热在这里只有精品15| 欧美日韩国产另类一区| 国产亚洲美州欧州综合国| 亚洲国产一区二区三区| 国精产品一区一区三区mba桃花| 91麻豆精东视频| 亚洲精品一区二区在线观看| 亚洲精品写真福利| 国产成人一区在线| 欧美裸体一区二区三区| 国产精品美女一区二区三区| 美女网站在线免费欧美精品| 色婷婷亚洲综合| 久久久www免费人成精品| 亚洲高清免费在线| voyeur盗摄精品| 欧美精品一区在线观看| 午夜欧美在线一二页| 成人sese在线| 久久综合久久综合亚洲| 亚洲香蕉伊在人在线观| 波多野结衣一区二区三区| 欧美成人乱码一区二区三区| 亚洲伊人色欲综合网| 成人黄色小视频| 欧美mv和日韩mv国产网站| 一区二区三区免费观看| 国产不卡视频在线观看| 欧美www视频| 日韩精品亚洲一区二区三区免费| 色悠悠亚洲一区二区| 国产日产欧美一区| 国产主播一区二区| 日韩午夜在线观看| 首页国产欧美日韩丝袜| 91成人免费在线| 亚洲三级小视频| 成人激情校园春色| 中文字幕av不卡| 国产不卡视频在线观看| 精品国产一区二区三区av性色| 亚洲va天堂va国产va久| 欧美综合一区二区| 亚洲女与黑人做爰| 91免费版在线| 亚洲欧美自拍偷拍色图| 99国产精品一区| 国产精品久久久久精k8| 成人网在线播放| 国产精品网站在线| 99久久精品情趣| 中文字幕在线观看一区| 北条麻妃一区二区三区| 国产精品免费免费| 99精品欧美一区二区三区小说| 中文字幕不卡在线| 91啪亚洲精品| 亚洲欧美色图小说| 在线视频国内自拍亚洲视频| 亚洲欧美另类小说| 欧美日韩精品欧美日韩精品一| 亚洲中国最大av网站| 在线播放亚洲一区| 日本午夜一本久久久综合| 欧美变态tickle挠乳网站| 精品亚洲成a人在线观看| 2023国产精品视频| 成人小视频免费观看| 欧美国产激情二区三区| 97se亚洲国产综合自在线观| 午夜精品123| 精品国产一区a| 风间由美性色一区二区三区| 国产精品无人区| 在线免费观看一区| 日韩高清欧美激情| 337p粉嫩大胆噜噜噜噜噜91av| 风间由美一区二区三区在线观看| 国产精品久久久久桃色tv| 色呦呦网站一区| 青青草视频一区| 欧美国产激情一区二区三区蜜月| 色综合久久中文综合久久牛| 亚洲午夜视频在线观看| 日韩三级在线观看| 丁香亚洲综合激情啪啪综合| 亚洲精品高清视频在线观看| 91精品国产欧美一区二区18| 国产裸体歌舞团一区二区| 亚洲天堂2014| 欧美裸体bbwbbwbbw| 国产成人超碰人人澡人人澡| 亚洲精品五月天| 精品日韩欧美在线| 99精品国产99久久久久久白柏 | 日韩国产欧美在线视频| 久久一区二区三区四区| 91原创在线视频| 天使萌一区二区三区免费观看| 久久久亚洲综合| 欧美三级视频在线| 国产露脸91国语对白| 亚洲国产欧美一区二区三区丁香婷| 日韩一区二区电影在线| 一本色道亚洲精品aⅴ| 久草精品在线观看| 亚洲国产成人av网| 国产日韩精品一区二区浪潮av| 欧美日韩在线不卡| 国产91对白在线观看九色| 五月天激情小说综合| 国产精品久久毛片a| 日韩美女视频一区二区在线观看| 一本一本久久a久久精品综合麻豆| 久久国产剧场电影| 亚洲二区在线视频| 中文字幕一区三区| 久久久不卡网国产精品二区|