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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? scriptrunner.java

?? 本套系統(tǒng)采用了業(yè)界當(dāng)前最為流行的beanAction組件
?? JAVA
字號(hào):
/*
 *  Copyright 2004 Clinton Begin
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package com.ibatis.common.jdbc;

import com.ibatis.common.resources.Resources;


import java.io.IOException;
import java.io.LineNumberReader;
import java.io.PrintWriter;
import java.io.Reader;
import java.sql.*;

/**
 * Tool to run database scripts
 */
public class ScriptRunner {

  //private static final Log log = LogFactory.getLog(ScriptRunner.class);


  private Connection connection;
  private String driver;
  private String url;
  private String username;
  private String password;

  private boolean stopOnError;
  private boolean autoCommit;

  private PrintWriter logWriter = new PrintWriter(System.out);
  private PrintWriter errorLogWriter = new PrintWriter(System.err);

  /**
   * Default constructor
   */
  public ScriptRunner(Connection connection, boolean autoCommit, boolean stopOnError) {
    this.connection = connection;
    this.autoCommit = autoCommit;
    this.stopOnError = stopOnError;
  }

  public ScriptRunner(String driver, String url, String username, String password, boolean autoCommit, boolean stopOnError) {
    this.driver = driver;
    this.url = url;
    this.username = username;
    this.password = password;
    this.autoCommit = autoCommit;
    this.stopOnError = stopOnError;
  }

  /**
   * Setter for logWriter property
   *
   * @param logWriter - the new value of the logWriter property
   */
  public void setLogWriter(PrintWriter logWriter) {
    this.logWriter = logWriter;
  }

  /**
   * Setter for errorLogWriter property
   *
   * @param errorLogWriter - the new value of the errorLogWriter property
   */
  public void setErrorLogWriter(PrintWriter errorLogWriter) {
    this.errorLogWriter = errorLogWriter;
  }

  /**
   * Runs an SQL script (read in using the Reader parameter)
   *
   * @param reader - the source of the script
   */
  public void runScript(Reader reader) throws IOException, SQLException{
    try {
      if (connection == null) {
        DriverManager.registerDriver((Driver) Resources.classForName(driver).newInstance());
        Connection conn = DriverManager.getConnection(url, username, password);
        try {
          if (conn.getAutoCommit() != autoCommit) {
            conn.setAutoCommit(autoCommit);
          }
          runScript(conn, reader);
        } finally {
          conn.close();
        }
      } else {
        boolean originalAutoCommit = connection.getAutoCommit();
        try {
          if (originalAutoCommit != this.autoCommit) {
            connection.setAutoCommit(this.autoCommit);
          }
          runScript(connection, reader);
        } finally {
          connection.setAutoCommit(originalAutoCommit);
        }
      }
    } catch (IOException e) {
      throw e;
    } catch (SQLException e) {
      throw e;
    } catch (Exception e) {
      throw new RuntimeException("Error running script.  Cause: " + e, e);
    }
  }

  /**
   * Runs an SQL script (read in using the Reader parameter) using the connection passed in
   *
   * @param conn   - the connection to use for the script
   * @param reader - the source of the script
   * @throws SQLException if any SQL errors occur
   * @throws IOException  if there is an error reading from the Reader
   */
  private void runScript(Connection conn, Reader reader)
      throws IOException, SQLException {
    StringBuffer command = null;
    try {
      LineNumberReader lineReader = new LineNumberReader(reader);
      String line = null;
      while ((line = lineReader.readLine()) != null) {
        if (command == null) {
          command = new StringBuffer();
        }
        String trimmedLine = line.trim();
        if (trimmedLine.startsWith("--")) {
          println(trimmedLine);
        } else if (trimmedLine.length() < 1 || trimmedLine.startsWith("//")) {
          //Do nothing
        } else if (trimmedLine.length() < 1 || trimmedLine.startsWith("--")) {
          //Do nothing
        } else if (trimmedLine.endsWith(";")) {
          command.append(line.substring(0, line.lastIndexOf(";")));
          command.append(" ");
          Statement statement = conn.createStatement();

          println(command);

          boolean hasResults = false;
          if (stopOnError) {
            hasResults = statement.execute(command.toString());
          } else {
            try {
              statement.execute(command.toString());
            } catch (SQLException e) {
              e.fillInStackTrace();
              printlnError("Error executing: " + command);
              printlnError(e);
            }
          }

          if (autoCommit && !conn.getAutoCommit()) {
            conn.commit();
          }

          ResultSet rs = statement.getResultSet();
          if (hasResults && rs != null) {
            ResultSetMetaData md = rs.getMetaData();
            int cols = md.getColumnCount();
            for (int i = 0; i < cols; i++) {
              String name = md.getColumnName(i);
              print(name + "\t");
            }
            println("");
            while (rs.next()) {
              for (int i = 0; i < cols; i++) {
                String value = rs.getString(i);
                print(value + "\t");
              }
              println("");
            }
          }

          command = null;
          try {
            statement.close();
          } catch (Exception e) {
            // Ignore to workaround a bug in Jakarta DBCP
          }
          Thread.yield();
        } else {
          command.append(line);
          command.append(" ");
        }
      }
      if (!autoCommit) {
        conn.commit();
      }
    } catch (SQLException e) {
      e.fillInStackTrace();
      printlnError("Error executing: " + command);
      printlnError(e);
      throw e;
    } catch (IOException e) {
      e.fillInStackTrace();
      printlnError("Error executing: " + command);
      printlnError(e);
      throw e;
    } finally {
      conn.rollback();
      flush();
    }
  }

  private void print(Object o) {
    if (logWriter != null) {
      System.out.print(o);
    }
  }

  private void println(Object o) {
    if (logWriter != null) {
      logWriter.println(o);
    }
  }

  private void printlnError(Object o) {
    if (errorLogWriter != null) {
      errorLogWriter.println(o);
    }
  }

  private void flush() {
    if (logWriter != null) {
      logWriter.flush();
    }
    if (errorLogWriter != null) {
      errorLogWriter.flush();
    }
  }


}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级一区二区| 成人黄色小视频在线观看| 免费人成网站在线观看欧美高清| 精品亚洲国内自在自线福利| 成人黄色软件下载| 欧美高清一级片在线| 国产精品毛片a∨一区二区三区| 日韩电影在线免费看| 97成人超碰视| 中日韩av电影| 另类小说色综合网站| 欧美日韩精品免费| 亚洲欧美经典视频| 国产成人精品一区二区三区网站观看| 欧美日韩视频第一区| 中文字幕一区二区不卡 | 亚洲精品v日韩精品| 久久99久久精品欧美| 欧美日韩一级二级| 亚洲欧洲韩国日本视频| 国产91在线|亚洲| 久久久不卡网国产精品二区| 日韩中文字幕不卡| 欧美浪妇xxxx高跟鞋交| 亚洲欧美日韩人成在线播放| 成人app在线观看| 国产欧美一区二区三区沐欲| 国产伦精品一区二区三区免费迷| 欧美一区二区视频网站| 亚洲第一激情av| 欧美熟乱第一页| 亚洲国产欧美日韩另类综合 | 欧美人妇做爰xxxⅹ性高电影| 亚洲欧洲日韩女同| 成人动漫中文字幕| 国产精品私人影院| 成年人网站91| 亚洲精品国产无天堂网2021| 色欧美日韩亚洲| 亚洲一区二区视频在线| 欧美嫩在线观看| 午夜精品福利一区二区三区蜜桃| 欧美亚洲国产一区在线观看网站 | 26uuu精品一区二区三区四区在线| 日韩激情中文字幕| 欧美精品一级二级| 裸体歌舞表演一区二区| 久久久青草青青国产亚洲免观| 国产一区福利在线| 国产精品美女久久久久aⅴ| 波多野洁衣一区| 椎名由奈av一区二区三区| 色综合欧美在线视频区| 午夜国产不卡在线观看视频| 欧美情侣在线播放| 精品亚洲欧美一区| 国产欧美日本一区二区三区| 不卡av电影在线播放| 亚洲黄色录像片| 欧美日韩精品一区二区在线播放| 日韩中文字幕av电影| 久久久天堂av| 色欧美日韩亚洲| 美女视频黄免费的久久| 国产丝袜在线精品| 91丨porny丨最新| 水蜜桃久久夜色精品一区的特点| 精品久久人人做人人爱| 成人app在线观看| 日本aⅴ精品一区二区三区| 2023国产精品视频| 在线一区二区观看| 精品一区二区精品| 亚洲午夜在线视频| 精品国产一二三| 色综合久久中文字幕| 韩国女主播成人在线观看| 中文字幕在线观看不卡视频| 欧美精品粉嫩高潮一区二区| 国产精品一二一区| 亚洲成av人片一区二区梦乃| 国产丝袜美腿一区二区三区| 欧美人妖巨大在线| 成人美女视频在线看| 日韩高清电影一区| 亚洲女同一区二区| 久久先锋影音av鲁色资源| 在线观看不卡视频| 成人夜色视频网站在线观看| 日本三级亚洲精品| 亚洲激情自拍偷拍| 中文字幕第一区| 日韩你懂的在线观看| 欧美在线视频全部完| av不卡一区二区三区| 国产一区二区按摩在线观看| 天天做天天摸天天爽国产一区| 国产精品乱人伦一区二区| 精品少妇一区二区三区在线播放 | 日韩伦理电影网| 久久综合久久综合久久| 在线免费观看一区| 91美女视频网站| 成人午夜私人影院| 国产伦精品一区二区三区在线观看| 午夜电影一区二区三区| 亚洲综合成人网| 亚洲色图欧洲色图婷婷| 国产精品美女www爽爽爽| 久久久久久久久岛国免费| 欧美一区二区日韩| 欧美国产精品一区二区三区| 精品成人a区在线观看| 欧美色大人视频| 欧美午夜理伦三级在线观看| 色猫猫国产区一区二在线视频| 成人一区二区视频| 成人网页在线观看| av在线不卡网| 成人av在线播放网址| k8久久久一区二区三区| 成人av在线网| 99国内精品久久| 在线看国产日韩| 欧美日韩国产综合视频在线观看| 欧美性大战久久| 在线成人av网站| 3atv一区二区三区| 欧美一区二区黄色| 欧美不卡一二三| 国产欧美综合色| 亚洲精品成人少妇| 尤物在线观看一区| 午夜精品久久久久久久| 午夜国产不卡在线观看视频| 午夜精品福利一区二区三区蜜桃| 奇米色一区二区| 国产a区久久久| 欧美最猛性xxxxx直播| 欧美日韩第一区日日骚| 日韩女优av电影| 国产精品视频九色porn| 一个色妞综合视频在线观看| 视频一区二区中文字幕| 国产一区二区三区综合| 96av麻豆蜜桃一区二区| 欧美日韩一区二区在线观看| 欧美mv日韩mv国产网站app| 国产欧美精品一区| 一区二区三区在线免费视频| 日本在线不卡一区| 成人黄色在线视频| 欧美日韩国产123区| 2023国产精品自拍| 亚洲国产精品久久久久秋霞影院| 精品中文字幕一区二区| 成人的网站免费观看| 欧美一区二区三区四区久久| 国产精品久久久久久久久免费樱桃 | 美女脱光内衣内裤视频久久网站 | 国产精品麻豆一区二区| 天天av天天翘天天综合网| 国产激情一区二区三区四区| 91黄色在线观看| 久久久一区二区三区捆绑**| 亚洲综合色婷婷| 国产成人久久精品77777最新版本| 日本高清免费不卡视频| 久久精品欧美日韩| 日精品一区二区三区| 色综合久久久久久久| 日韩精品中午字幕| 一区二区成人在线观看| 成人夜色视频网站在线观看| 日韩一二在线观看| 一区二区久久久久久| 国产91精品一区二区麻豆网站 | 久久久国产精品午夜一区ai换脸| 一区二区三区精品视频| 成人视屏免费看| 欧美一级夜夜爽| 亚洲6080在线| 欧美性猛交一区二区三区精品 | 久久久久99精品国产片| 亚洲高清不卡在线观看| av不卡免费在线观看| 久久久99久久| 极品少妇xxxx偷拍精品少妇| 欧美日韩一区二区三区视频| 亚洲三级电影网站| 成人激情文学综合网| 欧美刺激午夜性久久久久久久 | 韩国欧美一区二区| 日韩午夜在线播放| 奇米影视一区二区三区小说| 欧美三级电影网| 午夜精品久久久久久久| 欧美日韩亚洲综合| 亚洲成a人在线观看| 欧美三级电影在线观看|