新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   >>中国XML论坛<<     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论Java, J2SE, J2ME, J2EE, 以及Eclipse, NetBeans, JBuilder等Java开发环境,还有JSP, JavaServlet, JavaBean, EJB以及struts, hibernate, spring, webwork2, Java 3D, JOGL等相关技术。
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Java/Eclipse 』 → jdbc资源的回收问题[转载] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 11284 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: jdbc资源的回收问题[转载] 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18406
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Java/Eclipse 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 jdbc资源的回收问题[转载]

    ● jdbc资源的回收问题[转载]发信人: petbear (雨中的人), 信区: J2EE
    标  题: jdbc资源的回收问题[转载]
    发信站: BBS 水木清华站 (Sun May  9 11:33:20 2004), 站内


    我们使用连接池访问数据库,是不是在关闭了connection之后它所属的statement和resul
    t都会自动关闭了呢?就是说只需要关闭connection?
    那么这样的话是不是只要在try{...}catch{...}finnally{conn.close();}这样的框架下工
    作就肯定是不会存在连接资源占用的情况了呢?
    经过我在DB2上测试的情况是这样的,不知道是不是不同的jdk或者as环境下会有所不同?
    我一直无法完全肯定这一问题,请大家赐教!
    本来我只要养成在关闭connection之前把其他对象一一关闭的习惯,就不会存在这个问题
    了,但是我为了偷懒起见,把简单的查询和更新操作封装到了一个基类的公用函数中,方
    便随时在代码中调用,代码如下:
    public static ResultSet sysSelect(Connection conn,String sql)throws SQLExcepti
    on{
    Statement st = null;
    st = conn.createStatement();
    return st.executeQuery(sql);
    }
    由于这样的功能随时随地会被使用,这不得不使我考虑这个函数中产生中间对象statemen
    t st的生存期问题!*_*

    Re: jdbc资源的回收问题!  发表时间: 2004年04月15日 10:47:19   回复

    发表人: FgtPWD    发表文章: 6 / 注册时间: 2004-04
    帮你顶,我也想知道清楚


    Re: jdbc资源的回收问题!  发表时间: 2004年04月15日 14:56:56   回复

    发表人: oldma    发表文章: 86 / 注册时间: 2003-09
    是,最起码数据库端资源是得到了释放
    不过这也不绝对,因为statement,result对应的是curior,而有些
    DB的curior是share的,
    总之,关了connection就可以了


    Re: jdbc资源的回收问题!  发表时间: 2004年04月16日 17:05:07   回复

    发表人: mysapphire    发表文章: 17 / 注册时间: 2003-12
    你是说:在有的时候就算是释放了connection也可能有部分的Statement和ResultSet还占
    用着数据库资源?
    如果是这样的话,那么在这个时候java和数据库的连接虽然断开了,可由于没有在连接的
    时候预先释放这些Statement和ResultSret资源(在数据库方应该理解为游标或者其他资源
    ),会影响数据库的性能的吧?这似乎无以从程序上来证实!


    Re: jdbc资源的回收问题!  发表时间: 2004年04月18日 20:41:05   回复

    发表人: oldma    发表文章: 86 / 注册时间: 2003-09
    &gt; 你是说:在有的时候就算是释放了connection也可能有部分的                        
    &gt; tatement和ResultSet还占用着数据库资源?                                       
    不会,本地的statement和ResultSet会被回收,但数据库端的资源不一定会释放,但你不
    必担心此事,应为这不是一件坏事,就像你用的数据库连接池,数据库也可以对curior做
    cache,毕竟频繁创建curior对DB来说是比较expansive的.
    当然,前提是数据库share_curior参数的设置不是0


    Re: jdbc资源的回收问题!  发表时间: 2004年04月16日 17:16:17   回复

    发表人: seaman0916    发表文章: 19 / 注册时间: 2004-02
    关注,我对这个问题也一直搞不清楚!


    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 12:51:46   回复

    发表人: TiGEr.zZ    发表文章: 7 / 注册时间: 2004-04
    本地对象如果不被使用的确可以释放,但tcp连接什么时候释放是个问题,还有tcp连接和
    connection对应还是和resultset对应,这个似乎是未知的,不过看起来java里似乎是和c
    onnection对应的,否则只需要全局维护一个长连接connection对象就可以了,只考虑生成
    (是否可用)的问题而不用考虑关闭的问题(除非出于性能目的,可以考虑多连接加锁的实
    现,也无需用户去关闭),ado里面好像可以这么做。如果tcp连接过多,一定会把数据库拖
    垮的。
    至于conn, rs, st之间的依赖关系似乎也不明确,所以我在这个时候是自己写一个result
    set接口的实现,然后重载close方法,去一一关闭其依赖对象,甚至你可以在final函数里
    面关闭,不过后者看起来没什么大用。


    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 13:37:52   回复

    发表人: navyzhu    发表文章: 7 / 注册时间: 2003-03
    Statement也要Close,本人在使用中发现,若单单调用Connection.Close,实际上Connect
    ion并不会立即Close,可能要等到垃圾回收Statement后Connection才会Close, 本人使用的
    数据库是SQLServer.


    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 14:48:17   回复

    发表人: jellyprince    发表文章: 11 / 注册时间: 2004-04
    我曾试过将Connection对象作为一个static属性放在一个类DBConnection中,然后,建立
    一个连接后,其它所有要用连接的地方就调用
    DBConnection.connection,
    最后再关掉,本以为这是一高招,但结果却是不可行。connection被用一次后,调用DBCo
    nnection.connection时就不行了。
    但我认为思路应该是对的,不知是否还有同志尝试过
    至于statement,要关掉并不难,可以在一个要连某个数据库的类中将其可connection一同
    声明为static,这样在任何地方用完后,就可以很方便的关掉了


    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 14:53:33   回复

    发表人: rtm    发表文章: 13 / 注册时间: 2002-11
    全部都要关闭,关闭connection后statement和result还是可以用的,可以在关闭connect
    ion后,再试试遍历result还是可以得到数据的,result不关闭会导致游标超出范围等错误



    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 15:13:02   回复

    发表人: mysapphire    发表文章: 17 / 注册时间: 2003-12
    请问navyzhu和rtm: 你们是在什么数据库上测试得到的这个结果的?
    我在DB2和ORACLE8.1.2上测试出来的结果都很明显地提示:SQLException:关闭的连接...
    .(所有的conn,st,rs使用的时候是默认方式)


    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 15:22:43   回复

    发表人: huzhigang    发表文章: 23 / 注册时间: 2003-12
    Connection一旦关闭,所有由它打开的ResultSet不在可用。这在jdk文档中有说明。否则
    ,没有必要定义javax.sql.RowSet了。


    Re: jdbc资源的回收问题!  发表时间: 2004年04月20日 10:50:17   回复

    发表人: shardy    发表文章: 4 / 注册时间: 2003-04
    Statement,ResultSet肯定都是关闭了得,但是资源还没有释放阿。如果从性能方面考虑的
    话,一定的明显的关闭Statement,ResultSet,还有两点需要注意:
    1,不要隐式产生Statement,ResultSet对象
    2,关闭对象一定要在finally中关闭


    Re: jdbc资源的回收问题!  发表时间: 2004年04月19日 15:21:25   回复

    发表人: TiGEr.zZ    发表文章: 7 / 注册时间: 2004-04
    这么看来odbc/jdbc的设计现在也不太适宜了,为什么有conn, st的存在是因为希望可以复
    用,减少开销,但增加了程序员的负担,可能不多的几行代码,建立对象和关闭对象占了
    一半。甚至复用也很难实现,因为很多页面中可能只访问一两次数据库,如果没有自己设
    计或者底层的连接池,页面切换该消耗的还是要消耗。就算不是这样,按照设计的一般标
    准,需要把粒度细化,这样结果和上面一样,如果要重用,必须附加上多余的耦合变量,
    更加不好。
    反过来有了连接池,也基本上不需要conn,或者st,后者根据使用者的经验,似乎可以表
    达为得到rs后就可以关闭或者直接重用。conn也是可以重用的(否则也就不能连接池了)
    ,不过大概需要在前一个返回的resultset被关闭之后,也就是我说的和tcp连接对应的概
    念,这个和ado不同。


    Re: jdbc资源的回收问题(To mysapphire)!  发表时间: 2004年04月19日 17:48:06
    回复

    发表人: navyzhu    发表文章: 7 / 注册时间: 2003-03
    我用的数据库是SQLServer2000,程序是一个数据月结程序,开始我发现月结有时成功,有
    时失败,看了后台才发现因为Statement没有Close,所以Connection太多以至于打开几百个
    Connection,结果处理失败。


    Re: jdbc资源的回收问题!  发表时间: 2004年04月20日 11:01:32   回复

    发表人: xunzy    发表文章: 4 / 注册时间: 2004-04
    JDBC3.0规范中提出了一个新的规范:把Statement也进行缓存(一般是应用服务器厂商实
    现),这样就可以在不同的connection之间可以共享Statement。所以我个人以为,在释放
    connection之前,最好先close Statement,这样有利于statement的重用(而且这也是规
    范所推荐的比较好的编程习惯)。


    Re: jdbc资源的回收问题!  发表时间: 2004年04月20日 11:35:01   回复

    发表人: cats_tiger    发表文章: 79 / 注册时间: 2003-05
    Statement和PreparedStatement已经将数据库操作封装的很好了,所以我从来不再作一个
    类完成类似的操作。另外connection资源一定要用完就关。不要返回ResultSet对象,用R
    owSet代替。


    Re: jdbc资源的回收问题!  发表时间: 2004年04月20日 16:34:19   回复

    发表人: arthurlian    发表文章: 5 / 注册时间: 2003-09
    我在oracle中,如果不关statement,最后oracle会报错
    ORA-1000: max cursor exceeded.
    可以在 v$open_cursor中查询未关闭的cursor.
    最好还是用完就关。


    Re: jdbc资源的回收问题!  发表时间: 2004年04月20日 21:25:38   回复

    发表人: mysapphire    发表文章: 17 / 注册时间: 2003-12
    有一点应该是统一的吧?那就是:当直接connection.close()的时候java端的st对象资源
    必定已经被释放了,而在DB端相应的cursor资源也许不会马上释放,不同的DB厂商针对这
    有情况有不同的资源回收策略。
    但问题是:是不是正如oldma所说的那样,我们也可以把DB端的资源回收当作黑盒(或者一
    个能自我调整的容器)来看待,而不必去关心它的溢出或者阻塞???正如我们现在经常
    使用的连接池pool一样!!
    1)如果是这样的,那么我们可以只处理connection的关闭,因为connection的关闭会自动
    引起java端的rs、st和pst的关闭,而在DB端,则有cache可以复用这些未被显式释放的cu
    rsor资源,使这些资源不至于被挂起;
    2)如果不是这样,那么我们必须手工关闭rs、st和pst这些与数据库资源对应的对象来释
    放DB端的资源,然后在最后关闭conn,因为DB不会聪明地调度这些被挂起的资源,不主动关
    闭它们会导致DB资源被耗尽。
    通过回答这一问题,请大家告诉我,我在发帖的时候写的那个函数在极度频繁被调用时可
    行吗?因为这个函数不处理任何close()操作,只是根据调用者的connection参数和Strin
    g参数返回rs给调用者,在调用者的代码的最后会有rs.close()和connection.close()操作
    ,但是肯定不会有st.close()。 那么这个未被显式地close()的st就是我一直不清楚的东
    西,在非常频繁地被重复这样调用(事实上这样的调用就象out.print()一样多)后,D
    B端会是怎样一种情况?


    Re: jdbc资源的回收问题!(To mysapphire)  发表时间: 2004年04月21日 09:00:06
    回复

    发表人: navyzhu    发表文章: 7 / 注册时间: 2003-03
    对于频繁调用的函数Connecton及Statement绝对要Close,正如其他网友所说,不同的数据
    库可能有不同的实现,但考虑到重用及数据库的移植等问题,还是Close吧。


    Re: jdbc资源的回收问题!(To mysapphire)  发表时间: 2004年04月21日 09:24:03
    回复

    发表人: flag    发表文章: 3 / 注册时间: 2004-04
    有道理!



    ※ 来源:·BBS 水木清华站 smth.org·[FROM: 211.71.11.*]                          

    索引页面|上一篇|下一篇


       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/9/23 0:39:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Java/Eclipse 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/11/11 19:58:45

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    8,414.063ms