验证数据库安装 : 连接 « 数据库JDBC « Java

En
Java
1. 图形用户界面
2. 三维图形动画
3. 高级图形
4. 蚂蚁编译
5. Apache类库
6. 统计图
7. 
8. 集合数据结构
9. 数据类型
10. 数据库JDBC
11. 设计模式
12. 开发相关类
13. EJB3
14. 电子邮件
15. 事件
16. 文件输入输出
17. 游戏
18. 泛型
19. GWT
20. Hibernate
21. 本地化
22. J2EE平台
23. 基于J2ME
24. JDK-6
25. JNDI的LDAP
26. JPA
27. JSP技术
28. JSTL
29. 语言基础知识
30. 网络协议
31. PDF格式RTF格式
32. 映射
33. 常规表达式
34. 脚本
35. 安全
36. Servlets
37. Spring
38. Swing组件
39. 图形用户界面
40. SWT-JFace-Eclipse
41. 线程
42. 应用程序
43. Velocity
44. Web服务SOA
45. 可扩展标记语言
Java 教程
Java » 数据库JDBC » 连接屏幕截图 
验证数据库安装
 
import java.sql.*;

public class CheckJDBCInstallation {
  /**
   * Test Validity of JDBC Installation
   
   @param conn
   *          a JDBC connection object
   @param dbVendor
   *          db vendor {"oracle", "mysql" }
   @return true if a given connection object is a valid one; otherwise return
   *         false.
   @throws Exception
   *           Failed to determine if a given connection is valid.
   */
  public static boolean isValidConnection(Connection conn, String dbVendorthrows Exception {
    if (conn == null) {
      return false;
    }

    if (conn.isClosed()) {
      return false;
    }
    // depends on the vendor of the database:
    //
    // for MySQL database:
    // you may use the connection object
    // with query of "select 1"; if the
    // query returns the result, then it
    // is a valid Connection object.
    //
    // for Oracle database:
    // you may use the Connection object
    // with query of "select 1 from dual"; if
    // the query returns the result, then it
    // is a valid Connection object.
    if (dbVendor.equalsIgnoreCase("mysql")) {
      return testConnection(conn, "select 1");
    else if (dbVendor.equalsIgnoreCase("oracle")) {
      return testConnection(conn, "select 1 from dual");
    else {
      return false;
    }

  }

  /**
   * Test Validity of a Connection
   
   @param conn
   *          a JDBC connection object
   @param query
   *          a sql query to test against db connection
   @return true if a given connection object is a valid one; otherwise return
   *         false.
   */
  public static boolean testConnection(Connection conn, String query) {
    ResultSet rs = null;
    Statement stmt = null;
    try {
      stmt = conn.createStatement();
      if (stmt == null) {
        return false;
      }

      rs = stmt.executeQuery(query);
      if (rs == null) {
        return false;
      }

      // connection object is valid: you were able to
      // connect to the database and return something useful.
      if (rs.next()) {
        return true;
      }

      // there is no hope any more for the validity
      // of the Connection object
      return false;
    catch (Exception e) {
      // something went wrong: connection is bad
      return false;
    finally {
      // close database resources
      try {
        rs.close();
        stmt.close();        
      catch (SQLException e) {
        e.printStackTrace();
      }
    }
  }

  public static void main(String[] args) {
    Connection conn = null;
    try {
      String dbVendor = args[0];
      // get connection to a database
      System.out.println("dbVendor=" + dbVendor);
      System.out.println("conn=" + conn);
      System.out.println("valid connection = " + isValidConnection(conn, dbVendor));
    catch (Exception e) {
      // handle the exception
      e.printStackTrace();
      System.exit(1);
    finally {
      // release database resources
      try {
        conn.close();
      catch (SQLException e) {
        e.printStackTrace();
      }
    }
  }
}

           
         
  
Related examples in the same category
1. 连接到不止一个数据库
2. 调试数据库连接
3. 创建连接性能
4. 设置保存点
5. JDBC的简单连接
6. 加载一些驱动程序
7. 封装连接有关操作
8. 试验加载的驱动程序,并连接到数据库
9. 负载MySQL的JDBC驱动程序
10. 甲骨文JDBC驱动程序加载
11. 甲骨文JDBC驱动程序的负载测试: NewInstance
12. 试验注册的Oracle JDBC驱动程序
13. 安装的Oracle驱动程序和执行结果
14. Test Thin Net8 App
15. 指定一个字符集时,连接到一个数据库管理系统
16. 列出所有可用参数的创建一个JDBC连接
17. String java.sql.DriverPropertyInfo.name (Get name of property)
18. boolean java.sql.DriverPropertyInfo.required (Is property value required?)
19. String java.sql.DriverPropertyInfo.value (Get current value)
20. String java.sql.DriverPropertyInfo.description (Get description of property)
21. String[] java.sql.DriverPropertyInfo.choices (Get possible choices for property; if null, value can be any string)
22. 确定是否数据库支持交易
23. Committing and Rolling Back Updates to a Database
24. 停用自动commit模式中的JDBC
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.