使用JDBC访问MySql的一个公共方法的解决方案

JDBC访问MySQL的一个公共方法的解决方案,作者用了一个main方法直接测试,调用者在收到这个返回集合后可以根据实际情况进行解析,公共方法只是执行SQL,然后得到数据连接进行数据访问。



    本来项目都是用到例如Hibernate这些工具的,可是因为现在项目要求现在又丫的回到基于JDK的解决方案了。

    这个方法很简单,但是对于数据的连接使用连接池,连接池也是直接初始化的。

       
       
    1. package com;
    2. import java.sql.*;
    3. import java.util.*;
    4. import org.apache.commons.dbcp.BasicDataSource;
    5. /**
    6. * @说明 数据库连接管理
    7. * @author cuisuqiang
    8. */
    9. public class ConnectionManager {
    10. /**
    11. * @说明 执行一条SQL
    12. */
    13. @SuppressWarnings("unchecked")
    14. public static List<Object[]> excuteQuery(String sql) {
    15. Connection conn = null;
    16. PreparedStatement psta = null;
    17. ResultSet resultSet = null;
    18. List<Object[]> relist = new ArrayList<Object[]>(); // 总数据
    19. Object[] objects = null; // 每行数据
    20. try {
    21. conn = ConnectionManager.getConn(); // 得到链接
    22. if(null != conn){
    23. psta = conn.prepareStatement(sql);
    24. resultSet = psta.executeQuery(); // 执行查询,返回结果接集合
    25. int count = resultSet.getMetaData().getColumnCount(); // 一共有多少列数据
    26. // 循环行
    27. while (resultSet.next()) {
    28. objects = new Object[count];
    29. // 数据集索引从 1 开始,而数组存放时是从 0 开始
    30. for (int i = 1; i <= count; i++) {
    31. objects[i - 1] = resultSet.getObject(i);
    32. }
    33. relist.add(objects);
    34. }
    35. }
    36. } catch (Exception e) {
    37. e.printStackTrace();
    38. relist = null;
    39. } finally {
    40. try {
    41. if(null != resultSet)
    42. resultSet.close();
    43. if(null != psta)
    44. psta.close();
    45. if(null != conn)
    46. conn.close();
    47. } catch (Exception e2) {
    48. }
    49. }
    50. return relist;
    51. }
    52. private static org.apache.commons.dbcp.BasicDataSource ds = null;
    53. static {
    54. ds = new BasicDataSource(); // 组建数据源对象
    55. int initialSize = 1; // 连接池启动时的初始值
    56. int maxActive = 10; // 连接池的最大值
    57. int maxIdle = 1; // 最大空闲值
    58. int minIdle = 1; // 最小空闲值
    59. ds.setDriverClassName("com.mysql.jdbc.Driver");
    60. ds.setUrl("jdbc:mysql://192.168.154.128:3306/t2?useUnicode=true&characterEncoding=gbk");
    61. ds.setUsername("root");
    62. ds.setPassword("123456");
    63. ds.setInitialSize(initialSize);
    64. ds.setMaxActive(maxActive);
    65. ds.setMaxIdle(maxIdle);
    66. ds.setMinIdle(minIdle);
    67. }
    68. /**
    69. * 从数据源中取得数据库连接
    70. */
    71. public static Connection getConn() {
    72. try {
    73. return ds.getConnection();
    74. } catch (SQLException e) {
    75. e.printStackTrace();
    76. }
    77. return null;
    78. }
    79. }

    我使用的是BasicDataSource,你可能需要两个Jar包,commons-pool.jar,commons-dbcp.jar,连接mysql的话需要mysql-connector-java-3.1.13-bin.jar。

    写一个mian方法直接测试:

       
       
    1. package com;
    2. import java.util.List;
    3. public class T {
    4. @SuppressWarnings("unchecked")
    5. public static void main(String[] args) {
    6. try {
    7. List<Object[]> list = ConnectionManager.excuteQuery("select * from t");
    8. for (int i = 0; i < list.size(); i++) {
    9. Object[] os = list.get(i);
    10. for(Object o : os){
    11. if (o instanceof String) {
    12. String s = (String) o;
    13. String newStr = new String(s.getBytes("ISO-8859-1"),"GBK");
    14. System.out.print("字符串:" + newStr + "\t\t");
    15. }else if(o instanceof Long){
    16. Long s = (Long) o;
    17. System.out.print("浮点值:" + s + "\t\t");
    18. }else if(o instanceof Integer){
    19. Integer s = (Integer) o;
    20. System.out.print("整形值:" + s + "\t\t");
    21. }else{
    22. System.out.print("未知型:" + o + "\t\t");
    23. }
    24. }
    25. System.out.println();
    26. }
    27. } catch (Exception e) {
    28. e.printStackTrace();
    29. }
    30. }
    31. }

    我返回的是一个List集合,里面包含了一个Object数组。调用者在收到这个返回集合后可以根据实际情况进行解析,公共方法只是执行SQL,然后得到数据连接进行数据访问。

    原文链接:http://cuisuqiang.iteye.com/blog/1458557

    • 0
      点赞
    • 0
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值