当前位置:  开发笔记 > 编程语言 > 正文

复制ResultSet而不使用CachedRowSetImpl.execute()

如何解决《复制ResultSet而不使用CachedRowSetImpl.execute()》经验,为你挑选了1个好方法。

我正在尝试在执行查询后关闭连接.之前,我只是创建一个CachedRowSetImpl实例,它将负责为我释放资源.但是,我正在使用Hadoop项目的Hive数据库驱动程序.它不支持CachedRowSetImpl.execute().我想知道是否有其他方式可以让我复制ResultSet对象并关闭连接?



1> Serxipc..:

您可以CachedRowSet从现有填充a ResultSet:

public static RowSet executeQuery(String sql) throws Exception {
    Connection con = null;
    PreparedStatement ps = null;
    ResultSet rs = null;
    try{
        con = openConnection();
        ps = con.prepareStatement(sql);
        rs = ps.executeQuery();
        CachedRowSet rows = new CachedRowSetImpl();
        rows.populate(rs);
        return rows;
    }finally{
        rs.close();
        ps.close();
        con.close();            
    }       
}

推荐阅读
臭小子
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有