Java测试各种数据库连接(用Connection类)
源代码:
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类)的更多相关文章
- 自学Java测试代码 - 简单地Student类
2017-08-23 23:45:38 writer:pprp 写这个还蛮开心的 package test; public class Student { //创建成员变量 String name ...
- 1903021116—吉琛—Java第七周作业—客户类测试
项目 内容 课程班级博客链接 19信计班 这个作业要求链接 第七周作业链接 博客名称 学号-姓名-Java第七周作业-客户类测试 要求 每道题要有题目,代码(使用插入代码,不会插入代码的自己查资料解决 ...
- 1903021121-刘明伟-java第七周作业-客户类测试
项目 内容 课程班级博客链接 19信计班(本) 作业要求链接 作业要求链接 博客名称 1903021121-刘明伟-java第七周作业-客户类测试 要求 每道题要有题目,代码,截图 第一部分: 创建客 ...
- Java写的数据库连接池
原文地址: http://lgscofield.iteye.com/blog/1820521 import java.sql.*; import java.util.Enumeration; impo ...
- JAVA jdbc获取数据库连接
JDBC获取数据库连接的帮助类 import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManage ...
- java.sql.SQLException: Io 异常: Connection reset
当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行数据库操作时仍然使用的是无效的数据库连接,这样,就导致客户端程序报“ java.sql.SQLExc ...
- 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: ...
- java操作数据库的通用的类
package cn.dao; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; ...
- Java基础-DBCP连接池(BasicDataSource类)详解
Java基础-DBCP连接池(BasicDataSource类)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程 ...
随机推荐
- [Erlang36]kerl轻松管理安装各种OTP版本
kerl只有一个目标:让我们在不同的OTP版本间随意切换.他是一个纯Bash项目.简单实用的工作利器! Readme里面用法已说明得非常清楚了.建议按流程来一次. 1.下载 安装(一个bash脚本,根 ...
- JAVA环境下利用solrj二次开发SOlR搜索的环境部署常见错误
问题一:出现控制台坏的响应错误一Bad request 控制台出现错误如下: Bad Request request: http://hostIP:8983/solr/update?wt=javabi ...
- java环境和Tomcat环境
这些变量名是一样的,变量的值需要自己根据自己的安装位置来确定 JAVA_HOME C:\Program Files\Java\jdk1.8.0_151 CATALINA_HOME(这个可能不需要) D ...
- AngularJs2 构建简单的英雄编辑器
参考上一篇文章的步骤,重新把相关环境准备.目录结构走一遍. 这一次我们要开始创建真正的Angularjs项目了. 显示我们的英雄 我们要在应用中显示英雄数据 我们来为 AppComponent 添加两 ...
- WindowsPhone模拟简易Toast弹出框
Coding4Fun这个开源控件中有ToastPrompt这个弹出框组件,但是由于Coding4Fun太庞大,如果只用到ToastPrompt这个控件的话,整个引用不太值当的.于是自己写了一个差不多的 ...
- AutoMapper之如何开始,适合入门和演示
原来想应该介绍下背景说明下好处什么的,仔细想都是废话 ,直接上代码吧. 首先有两个类,一个是和数据库对应的实体 Student,一个是和页面展示相关的页面模型 StudentModel. /// &l ...
- 「BZOJ1426」收集邮票
题目链接 戳我 \(Solution\) 我们首先转换一下问题: 假设我们进行了k轮得到了所有种类的邮票 则所花费用为: \[(1+2+5+...+k)=\frac{(1+k)*k}{2}=\frac ...
- 百度地图API鼠标获取坐标
var map = new BMap.Map('map'); var poi = new BMap.Point(112.53, 37.87); map.enableScrollWheelZoom(); ...
- Dota2APP--第一天
从今天开始,下定决心自己独立开发一个有关于Dota2的APP,因为非常喜欢这个游戏恰好自己又是做iOS移动开发的所以萌生了这个想法.希望可以坚持下去,有喜欢dota2的朋友也可以提点建议. 一.项目的 ...
- SQL Full Join 的 Where条件
SQL需求是损益视图串资产负债视图 用Excel透视表模拟出来的结果就是 用SQL查询如下: 当Where条件是左边的视图的时候 select 损益视图.年 ,损益视图.年月 ,损益视图.期间 ,损益 ...