黑马程序员技术交流社区

标题: jdbc问题 [打印本页]

作者: 张磊    时间: 2011-10-8 20:33
标题: jdbc问题
不用连接池的情况下,Connection对象要设计成单例吗?
我记得以前用.net写QQ的时候,不用单例就得创建多个连接对象,用多个对象会出现数据库事务上的麻烦.有些数据库是不支持事物的
作者: 程钧杰    时间: 2011-10-8 20:39
我一般把装载类等一些语句直接写在静态方法里
把connection用单例实现 每次拿到getConnection
作者: 刘朋朋    时间: 2011-10-8 20:46
为了使连接管理服务具有最大的通用性,必须考虑多线程环境,即并发问题。这个问题相对比较好解决,因为Java语言自身提供了对并发管理的支持,使用synchronized关键字即可确保线程是同步的。使用方法为直接在类方法前面加上synchronized关键字,如:
public  synchronized  Connection  getConnection()   
作者: 林国锋    时间: 2011-10-8 20:54
给我发一个我上课学习用到的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. }
复制代码





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2