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

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

?? multidboperator.java

?? 使用resin3.0服務器, 默認情況下,jsp文件放到docmysideexamin目錄下. servlet類和在servlet類中使用的bean都放到docWEB-INFclasses目錄下.
?? 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一区二区三区免费野_久草精品视频
中文字幕的久久| 国产美女一区二区三区| 久久久99免费| 欧美亚洲综合另类| 成人福利在线看| 国产一区二区三区精品欧美日韩一区二区三区 | youjizz国产精品| 国产成人av一区二区三区在线 | 亚洲主播在线观看| 亚洲主播在线观看| 午夜私人影院久久久久| 婷婷开心激情综合| 美女在线视频一区| 国产伦精品一区二区三区免费| 国产一区中文字幕| 成人亚洲一区二区一| 99久久99久久精品国产片果冻| 一本久久精品一区二区 | 香蕉久久一区二区不卡无毒影院 | 欧美日韩一二区| 911国产精品| 久久亚洲精品国产精品紫薇| 国产三级久久久| 一区二区在线观看不卡| 日韩高清在线一区| 国产精品亚洲一区二区三区妖精| 北岛玲一区二区三区四区| 色综合久久99| 日韩精品一区二区三区在线播放| 中国色在线观看另类| 亚洲自拍偷拍九九九| 男男视频亚洲欧美| 成人福利在线看| 欧美精品丝袜中出| 国产精品污污网站在线观看| 亚洲尤物视频在线| 国产精品456露脸| 欧美日韩在线一区二区| 精品国产一区二区三区久久久蜜月 | 亚洲国产欧美一区二区三区丁香婷| 亚洲国产精品久久不卡毛片| 国产福利精品导航| 欧美日本免费一区二区三区| 中文字幕国产一区| 麻豆中文一区二区| 91国产成人在线| 国产日韩欧美电影| 视频精品一区二区| 一道本成人在线| 国产欧美日韩在线观看| 午夜激情综合网| 日本道免费精品一区二区三区| 日韩免费高清视频| 一区二区三区四区高清精品免费观看| 国产一区二区成人久久免费影院 | 欧美剧情片在线观看| 18欧美乱大交hd1984| 久久99精品国产.久久久久| 欧美怡红院视频| 亚洲精品视频一区二区| 国产成人免费xxxxxxxx| 精品乱人伦小说| 蜜臀精品一区二区三区在线观看| 色婷婷精品大在线视频| 一色桃子久久精品亚洲| 国产成人自拍高清视频在线免费播放| 欧美一区二区免费视频| 婷婷久久综合九色综合绿巨人| 欧洲精品一区二区| 一区二区三区在线不卡| 国产成人综合在线| 欧美国产日韩精品免费观看| 激情综合网最新| 精品久久免费看| 日本va欧美va欧美va精品| 欧美一区二区免费| 久久99热国产| 久久精品人人做人人综合| 国产成人免费在线视频| 欧美激情一区不卡| 99久久综合精品| 一区二区三区在线观看国产| 在线日韩一区二区| 天天av天天翘天天综合网色鬼国产| 欧美撒尿777hd撒尿| 舔着乳尖日韩一区| 日韩精品在线一区| 国产91综合网| 国产精品乱码一区二区三区软件 | 91亚洲精品一区二区乱码| 中文字幕制服丝袜成人av| 99久久99久久精品免费看蜜桃 | 91精品国产一区二区| 蜜臀av亚洲一区中文字幕| 亚洲精品一区二区三区四区高清| 国产一区不卡在线| 自拍偷拍亚洲欧美日韩| 欧美日韩精品欧美日韩精品一| 日韩成人免费看| 国产亚洲精品7777| 日本韩国欧美一区| 麻豆久久一区二区| 欧美国产国产综合| 欧美日韩三级视频| 国产一区二区精品久久91| 亚洲三级在线免费观看| 91精品国产综合久久小美女| 国产精品亚洲а∨天堂免在线| 亚洲欧美激情插| 日韩欧美一级二级| 91蜜桃在线观看| 国产在线精品免费| 一区二区成人在线视频| 精品国产乱码久久久久久1区2区| 国产suv精品一区二区三区| 一级中文字幕一区二区| 3atv一区二区三区| 成人一区二区三区视频| 日韩激情在线观看| 亚洲三级小视频| 久久这里只精品最新地址| 在线观看欧美精品| 风间由美一区二区三区在线观看 | 色老头久久综合| 国模冰冰炮一区二区| 亚洲图片欧美色图| 日本一区二区电影| 91精品免费在线观看| 99精品视频在线观看| 紧缚奴在线一区二区三区| 亚洲一区在线观看网站| 国产女人aaa级久久久级| 制服丝袜日韩国产| 色综合天天综合网天天狠天天| 国精产品一区一区三区mba桃花| 亚洲制服丝袜av| 国产精品久久国产精麻豆99网站| 精品少妇一区二区三区在线播放 | 国产清纯白嫩初高生在线观看91 | 奇米精品一区二区三区在线观看| 亚洲欧美一区二区不卡| 国产亚洲欧美激情| 久久先锋资源网| 欧美一区二区久久| 制服丝袜一区二区三区| 欧美高清激情brazzers| 色94色欧美sute亚洲线路二| 99久久久精品| av不卡免费在线观看| www.66久久| 99re这里只有精品首页| 粉嫩av一区二区三区在线播放| 国产乱码精品一区二区三| 国产一区福利在线| 国产精品一区二区在线观看网站 | 国产一区二区三区香蕉| 午夜精品一区二区三区电影天堂| 亚洲精品乱码久久久久久黑人| 国产精品国产三级国产aⅴ入口| 国产午夜精品久久| 国产精品久99| 亚洲一区在线视频观看| 一区二区三区小说| 亚洲高清视频在线| 亚洲成人你懂的| 男人的天堂亚洲一区| 国内精品伊人久久久久av影院| 天天色天天爱天天射综合| 天堂va蜜桃一区二区三区漫画版| 亚洲一卡二卡三卡四卡| 日韩福利电影在线| 激情五月激情综合网| 九一九一国产精品| 成人在线视频一区二区| 91蜜桃在线观看| 欧美日本一道本在线视频| 精品久久久三级丝袜| 欧美国产一区二区在线观看| 亚洲毛片av在线| 日韩成人av影视| 国产高清无密码一区二区三区| 99re66热这里只有精品3直播| 欧美调教femdomvk| 日韩欧美一区二区视频| 国产精品国产自产拍在线| 亚洲综合在线五月| 黑人巨大精品欧美一区| 91美女视频网站| 日韩午夜在线观看| 欧美国产精品专区| 亚洲成a人v欧美综合天堂下载| 久久成人免费日本黄色| 成年人网站91| 欧美一区二区视频在线观看2022| 国产亚洲欧美日韩俺去了| 婷婷久久综合九色综合绿巨人| 国产精品综合在线视频| 欧美午夜在线一二页| 久久久噜噜噜久久中文字幕色伊伊| 亚洲四区在线观看|