由ResultSet支持的Java迭代器

由ResultSet支持的Java迭代器,第1张

由ResultSet支持的Java迭代器

这是一个坏主意。这种方法要求连接一直保持打开状态,直到读取最后一行为止,并且在DAO层之外,您永远都不知道何时会发生连接,并且您似乎也保持结果集处于打开状态,并且在这种情况下可能会导致资源泄漏和应用程序崩溃连接超时。你不想那样。

正常JDBC的做法是,你购买

Connection
Statement
ResultSet
最短的
可能范围。通常的做法是,将多行映射到a
List
或a中,
Map
然后猜测它们 确实 有一个
Iterator

public List<Data> list() throws SQLException {    List<Data> list = new ArrayList<Data>();    try (        Connection connection = database.getConnection();        Statement statement = connection.createStatement("SELECt id, name, value FROM data");        ResultSet resultSet = statement.executeQuery();    ) {        while (resultSet.next()) { list.add(map(resultSet));        }    }    return list;}private Data map(ResultSet resultSet) throws SQLException {    Data data = new Data();     data.setId(resultSet.getLong("id"));    data.setName(resultSet.getString("name"));    data.setValue(resultSet.getInteger("value"));    return data;}

并如下使用:

List<Data> list = dataDAO.list(); int count = list.size(); // Easy as that.Iterator<Data> iterator = list.iterator(); // There is your Iterator.

不要像您最初想要的那样将昂贵的数据库资源传递到DAO层之外。有关常规JDBC实践和DAO模式的更多基本示例,您可能会发现本文很有用。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5489729.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-12
下一篇 2022-12-12

发表评论

登录后才能评论

评论列表(0条)

保存