设为首页 收藏本站
查看: 784|回复: 0

[经验分享] 使用JDBC访问MySql的一个公共方法的解决方案

[复制链接]

尚未签到

发表于 2016-10-22 10:56:16 | 显示全部楼层 |阅读模式
  本来项目都是用到例如Hibernate这些工具的,可是因为现在项目要求现在又丫的回到基于JDK的解决方案了。
  这个方法很简单,但是对于数据的连接使用连接池,连接池也是直接初始化的。

package com;
import java.sql.*;
import java.util.*;
import org.apache.commons.dbcp.BasicDataSource;
/**
* @说明 数据库连接管理
* @author cuisuqiang
*/
public class ConnectionManager {
/**
* @说明 执行一条SQL
*/
@SuppressWarnings("unchecked")
public static List<Object[]> excuteQuery(String sql) {
Connection conn = null;
PreparedStatement psta = null;
ResultSet resultSet = null;
List<Object[]> relist = new ArrayList<Object[]>(); // 总数据
Object[] objects = null; // 每行数据
try {
conn = ConnectionManager.getConn(); // 得到链接
if(null != conn){
psta = conn.prepareStatement(sql);
resultSet = psta.executeQuery(); // 执行查询,返回结果接集合
int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列数据
// 循环行
while (resultSet.next()) {
objects = new Object[count];
// 数据集索引从 1 开始,而数组存放时是从 0 开始
for (int i = 1; i <= count; i++) {
objects[i - 1] = resultSet.getObject(i);
}
relist.add(objects);
}
}
} catch (Exception e) {
e.printStackTrace();
relist = null;
} finally {
try {
if(null != resultSet)
resultSet.close();
if(null != psta)
psta.close();
if(null != conn)
conn.close();
} catch (Exception e2) {
}
}
return relist;
}
private static org.apache.commons.dbcp.BasicDataSource ds = null;
static {
ds = new BasicDataSource(); // 组建数据源对象
int initialSize = 1; // 连接池启动时的初始值
int maxActive = 10;  // 连接池的最大值
int maxIdle = 1;     // 最大空闲值
int minIdle = 1;     // 最小空闲值
ds.setDriverClassName("com.mysql.jdbc.Driver");
ds.setUrl("jdbc:mysql://192.168.154.128:3306/t2?useUnicode=true&characterEncoding=gbk");
ds.setUsername("root");
ds.setPassword("123456");
ds.setInitialSize(initialSize);
ds.setMaxActive(maxActive);
ds.setMaxIdle(maxIdle);
ds.setMinIdle(minIdle);
}
/**
* 从数据源中取得数据库连接
*/
public static Connection getConn() {
try {
return ds.getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}
}

  
  我使用的是BasicDataSource,你可能需要两个Jar包,commons-pool.jar,commons-dbcp.jar,连接mysql的话需要mysql-connector-java-3.1.13-bin.jar。
  写一个mian方法直接测试:

package com;
import java.util.List;
public class T {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
try {
List<Object[]> list = ConnectionManager.excuteQuery("select * from t");
for (int i = 0; i < list.size(); i++) {
Object[] os = list.get(i);
for(Object o : os){
if (o instanceof String) {
String s = (String) o;
String newStr = new String(s.getBytes("ISO-8859-1"),"GBK");
System.out.print("字符串:" + newStr + "\t\t");
}else if(o instanceof Long){
Long s = (Long) o;
System.out.print("浮点值:" + s + "\t\t");
}else if(o instanceof Integer){
Integer s = (Integer) o;
System.out.print("整形值:" + s + "\t\t");
}else{
System.out.print("未知型:" + o + "\t\t");
}
}
System.out.println();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
  我返回的是一个List集合,里面包含了一个Object数组。调用者在收到这个返回集合后可以根据实际情况进行解析,公共方法只是执行SQL,然后得到数据连接进行数据访问。
  
  请您到ITEYE看我的原创:http://cuisuqiang.iyunv.com
  或支持我的个人博客,地址:http://www.javacui.com
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-289798-1-1.html 上篇帖子: mysql 多表删除陷阱(跨库schema+别名的语法错误问题) 下篇帖子: 利用sqlyog 导入sql文件时,出现“MySQL SERVER has gone away”错误
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表