A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 张磊 黑马帝   /  2011-10-8 20:33  /  1974 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

不用连接池的情况下,Connection对象要设计成单例吗?
我记得以前用.net写QQ的时候,不用单例就得创建多个连接对象,用多个对象会出现数据库事务上的麻烦.有些数据库是不支持事物的

3 个回复

倒序浏览
我一般把装载类等一些语句直接写在静态方法里
把connection用单例实现 每次拿到getConnection

评分

参与人数 1技术分 +1 收起 理由
admin + 1

查看全部评分

回复 使用道具 举报
为了使连接管理服务具有最大的通用性,必须考虑多线程环境,即并发问题。这个问题相对比较好解决,因为Java语言自身提供了对并发管理的支持,使用synchronized关键字即可确保线程是同步的。使用方法为直接在类方法前面加上synchronized关键字,如:
public  synchronized  Connection  getConnection()   

评分

参与人数 1技术分 +2 收起 理由
admin + 2

查看全部评分

回复 使用道具 举报
给我发一个我上课学习用到的JDBC工厂
  1. package com.linguofeng.factory;

  2. import java.sql.Connection;
  3. import java.sql.SQLException;
  4. import org.apache.commons.dbcp.BasicDataSource;

  5. public class ConnectionFactory {
  6.         private static BasicDataSource bds = new BasicDataSource();
  7.         static {
  8.                 bds.setDriverClassName("com.mysql.jdbc.Driver");
  9.                 bds.setUrl("jdbc:mysql://127.0.0.1/mysql");
  10.                 bds.setUsername("root");
  11.                 bds.setPassword("root");
  12.                 bds.setMaxActive(2000);
  13.                 bds.setMaxIdle(20);
  14.                 bds.setMaxWait(5000);
  15.         }

  16.         public ConnectionFactory() {
  17.         }

  18.         public static java.sql.Connection getConnection() {
  19.                 java.sql.Connection con = null;
  20.                 try {
  21.                         con = bds.getConnection();
  22.                 } catch (SQLException e) {
  23.                         e.printStackTrace();
  24.                 }
  25.                 return con;
  26.         }

  27.         public static void close(java.sql.Connection con, java.sql.Statement stm,
  28.                         java.sql.ResultSet rs) {
  29.                 try {
  30.                         if (rs != null) {
  31.                                 rs.close();
  32.                                 rs = null;
  33.                         }
  34.                         if (stm != null) {
  35.                                 stm.close();
  36.                                 stm = null;
  37.                         }
  38.                         if (con != null) {
  39.                                 con.close();
  40.                                 con = null;
  41.                         }

  42.                 } catch (Exception e) {
  43.                         e.printStackTrace();
  44.                 }
  45.         }

  46.         public static void main(String[] args) {
  47.                 //  使用方法
  48.                 Connection con = ConnectionFactory.getConnection();
  49.                 System.out.println(con);
  50.         }
  51. }
复制代码
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马