首页 > 数据库技术 > 详细

jdbc 自己理解

时间:2015-03-05 16:59:27      阅读:284      评论:0      收藏:0      [点我收藏+]
1、connection = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:ZSORA10G", "gao", "admin");

如果代码里面始终就只有一个connection,是否可以写jdbc代码 可以!
但是会造成以下问题:例如有两个客户端访问数据库,共享一个connection  ,如果其中一个 回滚了,那么第二个当然也回滚了,

事物不安全    所以不共享一个数据库对象


所以在web项目中 都是 一个客户端 一个connection  。这样会导致 每次获取连接 都要初始化获取connection对象,这是非常消耗内存的




这就是为什么我们使用连接池,连接池里面初始化几个 连接,不够用的时候 就继续增加,不用的时候 再销毁点,连接池里面始终
保存固定的connection。 


关于connection.close的理解。 如果是 一个客户端一个connection ,那么使用之后肯定要关掉连接 connection.close。不然容易内存溢出


关于连接池的 调用关闭connection方法  不是立即就关闭,而是让对象回归到连接池里面。


这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。


连接池掉用关闭

 BasicDataSource implements DataSource

 public synchronized void close() throws SQLException {
        closed = true;
        GenericObjectPool oldpool = connectionPool;
        connectionPool = null;
        dataSource = null;
        try {
            if (oldpool != null) {
                oldpool.close();
            }
        } catch(SQLException e) {
            throw e;
        } catch(RuntimeException e) {
            throw e;
        } catch(Exception e) {
            throw new SQLNestedException("Cannot close connection pool", e);
        }
    }

jdbc 自己理解

原文:http://blog.csdn.net/ggjlvzjy/article/details/44084295

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!