JDBCに、RowSetという概念があるのを知っていますか?
もし知っている人がいたら、ResultSetとの違いを教えてください。
宜しくお願いします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答1件
0
ベストアンサー
従来のJDBCでは、Connection
,Statement
,ResultSet
の組み合わせでSQLの結果を操作していましたが、
RowSet
はこれをもっと使いやすくしたAPIです。
自信を持って解説できるほど使ったことはありませんが...たとえば、下記のような操作でデータベースにアクセスできます。
例:CachedRowSet
// Java7以上 public static void usingRowSet(String url, String user, String password) throws SQLException { final String sql = ... ; // SELECT * FROM your_table RowSetFactory rowSetFactory = RowSetProvider.newFactory(); try (CachedRowSet rowSet = rowSetFactory.createCachedRowSet()) { rowSet.setUrl(url); rowSet.setUsername(user); rowSet.setPassword(password); rowSet.setCommand(sql); rowSet.execute(); while (rowSet.next()) { String id = rowSet.getString(1); long val = rowSet.getInt(2); System.out.printf("%s, %d%n", id, val); } rowSet.beforeFirst(); // 先頭に巻き戻す while (rowSet.next()) { String id = rowSet.getString(1); long val = rowSet.getInt(2); System.out.printf("%s, %d%n", id, val); } } }
また、上記のCachedRowSet
を使えば、ResultSet
をコネクション切断後も利用することができます。
ResultSet rs = ... ; rowSet.populate(rs); rowSet.beforeFirst(); // 先頭に巻き戻す while (rowSet.next()) { // ... }
もちろん、更新の操作もできます。
詳細については、まずAPIドキュメントの説明(↓)を読んでみるのが良さそうです。
パッケージ javax.sql.rowset の説明 (Java SE 7 API 仕様)
投稿2014/08/27 13:36
総合スコア9388
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2014/09/01 00:38