源代码:

package cn.finedo.fdcollect_service.util;

import java.sql.Connection;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; public class DoConnection {
private static Logger logger = LogManager.getLogger(); public static Connection connection(String dbtype,String linktype,String tns,String ip,String port,String dbname,String username,String password){
Connection conn = null;
try {
String jdbcurl = "";
if ("ORACLE".equals(dbtype.toUpperCase())) {
if("单节点".equals(linktype)){
jdbcurl = "jdbc:oracle:thin:@" + ip + ":"
+ port + ":" + dbname;
}else{
jdbcurl = "jdbc:oracle:thin:@ "+ tns;
}
conn =DBHelper.initOracle(jdbcurl,username,password, false); } else if ("MYSQL".equals(dbtype.toUpperCase())) {
jdbcurl = "jdbc:mysql://" + ip + ":"
+ port + "/" + dbname
+ "?useUnicode=true&characterEncoding=utf-8";
conn =DBHelper.initMysql(jdbcurl, username,password, false); } else if ("DB2".equals(dbtype.toUpperCase())) {
jdbcurl = "jdbc:db2://" + ip + ":"
+ port + "/" + dbname;
conn =DBHelper.initDB2(jdbcurl, username,password, false); } else if ("SQLSERVER".equals(dbtype.toUpperCase())) {
jdbcurl = "jdbc:sqlserver://" + ip + ":"
+ port + ";DatabaseName=" + dbname;
conn =DBHelper.initSQLServer(jdbcurl, username,password, false); }else if("GREENPLUM".equals(dbtype.toUpperCase())){
/*jdbcurl = "jdbc:pivotal:greenplum://" + ip + ":"
+ port + ";DatabaseName=" + dbname;*/
jdbcurl = tns;
conn = DBHelper.initGreenPlum(jdbcurl, username, password, false);
}else if("HIVE".equals(dbtype.toUpperCase())){
/*jdbcurl = "jdbc:hive2://" + ip + ":"+port + "/default";*/
jdbcurl = tns;
conn = DBHelper.initHIVE(jdbcurl, username, password, false);
}else {
return null;
}
} catch (Exception e) {
logger.error("数据源连接失败",e);
return null;
} return conn;
} public static void close(Connection conn){
if (conn != null) {
DBHelper.closeDB(conn, null, null);
} else {
DBHelper.closeDB(conn, null, null);
}
}
}

DBHelper.java

package cn.finedo.fdcollect_service.util;

import java.sql.Connection;
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; public class DBHelper {
private static Logger logger = LogManager.getLogger();
// public static Connection conn=null;
/**
* @author Liyg
* @description 创建ORACLE连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @return
*/
public static Connection initOracle(String jdbcurl, String username, String password, boolean autoCommit) {
Connection conn=null;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
//连接数据库
conn = DriverManager.getConnection(jdbcurl, username, password);
conn.setAutoCommit(autoCommit);
// logger.debug(jdbcurl);
// logger.debug("username=【"+username+"】");
// logger.debug("Oracle DATABASE: Connection success!");
}catch(Exception se) {
//连接失败
// logger.debug("initOra:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
//System.exit(0);
logger.error("ORACLE连接失败",se);
return null;
}
return conn;
} /**
* @author Liyg
* @description 创建DB2连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @return
*/
public static Connection initDB2(String jdbcurl, String username, String password, boolean autoCommit) {
Connection conn=null;
try {
Driver driver=(Driver) Class.forName("com.ibm.db2.jcc.DB2Driver").newInstance();
//连接数据库
DriverManager.registerDriver(driver);
conn = DriverManager.getConnection(jdbcurl, username, password);
conn.setAutoCommit(autoCommit);
// logger.info("db2 DATABASE:" + jdbcurl + " Connection success!");
}catch(Exception se) {
// logger.debug("initDB2:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
logger.error("DB2连接失败",se);
return null;
}
return conn;
} /**
* @author Liyg
* @description 创建MYSQL连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @return
*/
public static Connection initMysql(String jdbcurl, String username, String password, boolean autoCommit) {
Connection conn=null;
try {
Class.forName("com.mysql.jdbc.Driver");
//连接数据库
conn = DriverManager.getConnection(jdbcurl, username, password);
conn.setAutoCommit(autoCommit);
// logger.debug(jdbcurl);
// logger.debug("username=【"+username+"】");
// logger.debug("MYSQL DATABASE: Connection success!");
}catch(Exception se) {
//连接失败
conn = null;
// logger.debug("initMYSQL:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
logger.error("MYSQL连接失败",se);
return null;
}
return conn;
} /**
* @author Liyg
* @description 创建SQLServer连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @return
*/
public static Connection initSQLServer(String jdbcurl, String username, String password, boolean autoCommit) {
Connection conn=null;
try {
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
// 连接数据库
conn = DriverManager.getConnection(jdbcurl, username, password);
conn.setAutoCommit(autoCommit);
// logger.debug(jdbcurl);
// logger.debug("username=【" + username + "】");
// logger.debug("SQLSERVER DATABASE: Connection success!");
} catch (Exception se) {
// 连接失败
// logger.debug("initSQLServer:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
// System.exit(0);
logger.error("SQLSERVER连接失败",se);
return null;
}
return conn;
} /**
* @author zk
* @description 创建GreenPlum连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @return
*/
public static Connection initGreenPlum(String jdbcurl, String username, String password, boolean autoCommit) {
Connection conn=null;
try {
Class.forName("com.pivotal.jdbc.GreenplumDriver");
//conn = DriverManager.getConnection("jdbc:pivotal:greenplum://192.168.229.146:5432;DatabaseName=database", "gpadmin", "111");
conn = DriverManager.getConnection(jdbcurl,username, password);
conn.setAutoCommit(autoCommit);
// logger.debug("GreenPlum DATABASE: Connection success!");
} catch (Exception se) {
// 连接失败
// logger.debug("GreenPlum:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
logger.error("GREENPLUM连接失败",se);
return null;
}
return conn;
} /**
* @author zk
* @description 创建HIVE连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @return
*/
public static Connection initHIVE(String jdbcurl, String username, String password, boolean autoCommit) {
Connection conn=null;
try {
Class.forName("org.apache.hadoop.hive.jdbc.HiveDriver");
//conn = DriverManager.getConnection("jdbc:pivotal:greenplum://192.168.229.146:5432;DatabaseName=database", "gpadmin", "111");
conn = DriverManager.getConnection(jdbcurl,username, password);
conn.setAutoCommit(autoCommit);
// logger.debug("HIVE: Connection success!");
} catch (Exception se) {
// 连接失败
// logger.debug("HIVE:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
logger.error("HIVE连接失败",se);
return null;
}
return conn;
}
/**
* @author Liyg
* @description 根据传入的数据源类型,创建Connection连接信息
* @param jdbcurl
* @param username
* @param password
* @param autoCommit
* @param dbtype
* @return
*/
public static Connection intiConnection(String jdbcdriver,String jdbcurl, String username, String password, boolean autoCommit, String dbtype) {
Connection conn = null;
try {
Class.forName(jdbcdriver);
// 连接数据库
conn = DriverManager.getConnection(jdbcurl, username, password);
conn.setAutoCommit(autoCommit);
// logger.debug(jdbcurl);
// logger.debug("username=【" + username + "】");
// logger.debug("SQLSERVER DATABASE: Connection success!");
} catch (Exception se) {
// 连接失败
// logger.debug("initSQLServer:"+jdbcurl + "\r\n" + " Connection failed! " + se.getMessage());
// System.exit(0);
logger.error("连接失败",se);
return null;
}
return conn;
} /**
* 关闭数据库
* @author Liyg
* @param conn
* @param pstmt
*/
public static void closeDB(Connection conn, PreparedStatement pstmt,ResultSet rs) {
try {
if (rs != null) {
rs.close();
}
rs = null; if (pstmt != null) {
pstmt.close();
}
pstmt = null; if (conn != null) {
conn.close();
}
conn = null;
} catch (Exception ee) {
// logger.info("关闭数据库操作异常:" + ee.getMessage());
logger.error("数据源关闭失败",ee);
}
} }

Java测试各种数据库连接(用Connection类)的更多相关文章

  1. 自学Java测试代码 - 简单地Student类

    2017-08-23  23:45:38 writer:pprp 写这个还蛮开心的 package test; public class Student { //创建成员变量 String name ...

  2. 1903021116—吉琛—Java第七周作业—客户类测试

    项目 内容 课程班级博客链接 19信计班 这个作业要求链接 第七周作业链接 博客名称 学号-姓名-Java第七周作业-客户类测试 要求 每道题要有题目,代码(使用插入代码,不会插入代码的自己查资料解决 ...

  3. 1903021121-刘明伟-java第七周作业-客户类测试

    项目 内容 课程班级博客链接 19信计班(本) 作业要求链接 作业要求链接 博客名称 1903021121-刘明伟-java第七周作业-客户类测试 要求 每道题要有题目,代码,截图 第一部分: 创建客 ...

  4. Java写的数据库连接池

    原文地址: http://lgscofield.iteye.com/blog/1820521 import java.sql.*; import java.util.Enumeration; impo ...

  5. JAVA jdbc获取数据库连接

    JDBC获取数据库连接的帮助类 import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManage ...

  6. java.sql.SQLException: Io 异常: Connection reset

    当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行数据库操作时仍然使用的是无效的数据库连接,这样,就导致客户端程序报“ java.sql.SQLExc ...

  7. spring+ibatis问题1—— 程序报错:java.sql.SQLException: Io 异常: Connection reset by peer, socket write error; ”或“java.sql.SQLException 关闭的连接”异常

    转自:http://blog.sina.com.cn/s/blog_1549fb0710102whz2.html spring+ibatis程序测试时报错:java.sql.SQLException: ...

  8. java操作数据库的通用的类

    package cn.dao; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; ...

  9. Java基础-DBCP连接池(BasicDataSource类)详解

    Java基础-DBCP连接池(BasicDataSource类)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程 ...

随机推荐

  1. Markdown编辑器——常用语法

    Markdown是什么? 简短来说,他就是一款特别适用于写博客的编辑器.为什么适合呢,因为它特别的方便.以博客园的编辑界面来说,它原本的界面是这样的(有没有一种Word2003的既视感): 但是,当你 ...

  2. Hadoop集群 -Eclipse开发环境设置

    1.Hadoop开发环境简介 1.1 Hadoop集群简介 Java版本:jdk-6u31-linux-i586.bin Linux系统:CentOS6.0 Hadoop版本:hadoop-1.0.0 ...

  3. SQL SERVER 查找锁信息

    通过系统的存储过程  sp_who 或 sp_who2 可以查找出所有的锁信息, 但是看不出是哪个表, 什么语句 当使用 sp_who 或 sp_who2 查找锁信息的时候, 有个 spid 信息,  ...

  4. Application可以被重用,从哪里看出来的?

    一开始Context是静态的,并且创建时赋值,然后校验用户访问权限的时候,出现了问题, 调试看到,每次请求的url都一样,我就发现了每次Contetx都是一样的, 说明每次请求的Application ...

  5. BitAdminCore框架更新日志20180524

    20180524更新内容 本次更新两个内容,一是增加windows service,二是增加邮件发送功能. windows service windows service用于定期跑服务,网上有一些提供 ...

  6. pageadmin 网站建设系统如何新建进程池并在站点中使用

    1.打开iis管理界面,右键应用程序池,点击添加应用程序池,添加界面如下图,注意pageadmin cms net版本选择4.0,托管模式建议选择集成模式. 2.添加完毕后,在网站中点击对应站点,点击 ...

  7. 【ocp-12c】最新CUUG OCP-071考试题库(48题)

    48.(10-12)choose the best answer View the Exhibit and examine the description for the PRODUCTS and S ...

  8. BZOJ4283: 魔法少女伊莉雅(最短路径图+最短路径树)

    题面 传送门 题解 太长了不想写了→_→ 题解 //minamoto #include<bits/stdc++.h> #define R register #define inf 0x3f ...

  9. AngularJS源码解析2:注入器的详解

    上一课,没有讲createInjector方法,只是讲了它的主要作用,这一课,详细来讲一下这个方法.此方法,最终返回的注册器实例对象有以下几个方法: invoke, instantiate, get, ...

  10. jquery源码解析:jQuery数据缓存机制详解2

    上一课主要讲了jQuery中的缓存机制Data构造方法的源码解析,这一课主要讲jQuery是如何利用Data对象实现有关缓存机制的静态方法和实例方法的.我们接下来,来看这几个静态方法和实例方法的源码解 ...