⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 execjdbc.java

📁 数据库测试工具Benchmark,主要对数据库的性能进行了详细的测试。
💻 JAVA
字号:
/*
 * ExecJDBC - Command line program to process SQL DDL statements, from   
 *             a text input file, to any JDBC Data Source
 *
 * Copyright (C) 2004-2006, Denis Lussier
 *
 */


import java.io.*;
import java.sql.*;
import java.util.*;


public class ExecJDBC {
  
  public static void main(String[] args) {
  
    Connection conn = null;
    Statement stmt = null;
    String rLine = null;
    StringBuffer sql = new StringBuffer();
    java.util.Date now = null;

    now = new java.util.Date();
    System.out.println("------------- ExecJDBC Start Date = " + now + 
                       "-------------");

    try {

    Properties ini = new Properties();
    ini.load( new FileInputStream(System.getProperty("prop")));
                                                                                
    // display the values we need
    System.out.println("driver=" + ini.getProperty("driver"));
    System.out.println("conn=" + ini.getProperty("conn"));
    System.out.println("user=" + ini.getProperty("user"));
    System.out.println("password=******");
                                                                                
    // Register jdbcDriver
    Class.forName(ini.getProperty( "driver" ));

    // make connection
    conn = DriverManager.getConnection(ini.getProperty("conn"),
      ini.getProperty("user"),ini.getProperty("password"));
    conn.setAutoCommit(true); 
                                                                                
    // Create Statement
    stmt = conn.createStatement();
                                                                                
      // Open inputFile
      BufferedReader in = new BufferedReader
        (new FileReader(jTPCCUtil.getSysProp("commandFile",null)));
      System.out.println("-------------------------------------------------\n");
  
      // loop thru input file and concatenate SQL statement fragments
      while((rLine = in.readLine()) != null) {

         String line = rLine.trim();

         if (line.length() == 0) {
           System.out.println("");  // print empty line & skip over it  
         } else {
    
           if (line.startsWith("--")) {
              System.out.println(line);  // print comment line
           } else {
               sql.append(line);
               if (line.endsWith(";")) {
                  execJDBC(stmt, sql);
                  sql = new StringBuffer();
               } else {
                 sql.append("\n");
               }
           }

         } //end if 
        
      } //end while

      in.close();

    } catch(IOException ie) {
        System.out.println(ie.getMessage());
    
    } catch(SQLException se) {
        System.out.println(se.getMessage());

    } catch(Exception e) {
        e.printStackTrace();

    //exit Cleanly
    } finally {
      try {
        if (conn !=null)
           conn.rollback();
           conn.close();
      } catch(SQLException se) {
        se.printStackTrace();
      } // end finally

    } // end try


    now = new java.util.Date();
    System.out.println("");
    System.out.println("------------- ExecJDBC End Date = " + now + 
                        "-------------");
                  

  } // end main


  static void execJDBC(Statement stmt, StringBuffer sql) {

    System.out.println("\n" + sql);

    try {

      long startTimeMS = new java.util.Date().getTime();
      stmt.execute(sql.toString().replace(';',' '));
      long runTimeMS = (new java.util.Date().getTime()) + 1 - startTimeMS;
      System.out.println("-- SQL Success: Runtime = " + runTimeMS + " ms --");
    
    }catch(SQLException se) {

      String msg = null;
      msg = se.getMessage();

      System.out.println
         ("-- SQL Runtime Exception -----------------------------------------");
      System.out.println
         ("DBMS SqlCode=" + se.getErrorCode() + "  DBMS Msg="); 
      System.out.println("  "+ msg + "\n" +
        "------------------------------------------------------------------\n");

    } // end try

  } // end execJDBCCommand

} // end ExecJDBC Class

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -