源代码:

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. wp8.1 调用智慧天气SmartWeatherAPI

    在调用api应用的过程,我们需要用hmac加密技术,它是一种基于hash的加密算法,通过一个双方共同约定的密钥,在发送message前,对密钥进行了sha散列计算,在生成消息又对此密钥进行了二次加密, ...

  2. Java ActiveMQ 讲解(一)理解JMS 和 ActiveMQ基本使用

    最近的项目中用到了mq,之前自己一直在码农一样的照葫芦画瓢.最近几天研究了下,把自己所有看下来的文档和了解总结一下. 一. 认识JMS 1.概述 对于JMS,百度百科,是这样介绍的:JMS即Java消 ...

  3. 关于Unity中MonoBehaviour的构造函数

    关于Unity中MonoBehaviour的构造函数 在学习Unity MVVM UI框架的时候,一不小给一个继承自MonoBehaviour类的子类编写了自定义构造函数,结果调Bug调了两个钟,特此 ...

  4. C#之工厂

    工厂在我看来分为三种分别都是简单工厂,工厂方法,和抽象工厂,这三种都是将使用和创建分开的一种模式 接下来我来介绍一下我理解的简单工厂模式: 在平时我们需要使用生产对象的一个类当我们需要new 一个对象 ...

  5. “全栈2019”Java第一百零三章:匿名内部类详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  6. redis cluster 的ERR max number of clients reached 问题排查

    早上发现微服务连不上redis cluster了,看来下日志如下 [root@win-jrh378d7scu 7005]# bin/redis-cli -c -h 15.31.213.183 -p 7 ...

  7. canvas+js+面向对象的圆形封装

    效果: Circle.js /* 1. 封装属性: x, y r, fillStyle strokeStyle opacity 2.render */ function Circle(option) ...

  8. Mondrian系列

    1.Mondrian Schema Workbench 概念及常用参数 2.Schema Workbench 启动慢解决办法 3.自己写的第一个Schema文件 4.维度-退化维度 5.维度-共享维度 ...

  9. 常见的http错误提示

    1xx(临时响应)表示临时响应并需要请求者继续执行操作的状态代码. 代码 说明100 (继续) 请求者应当继续提出请求.服务器返回此代码表示已收到请求的第一部分,正在等待其余部分. 101 (切换协议 ...

  10. CentOS 7 安装过程中设置网络

    如果在安装过程中需要使用网络,需要启动网卡,默认是DHCP 点击configure进入设置 General 常规设置 Automatically connect to this network whe ...