91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中如何使用ResultSet實現遍歷數據

發布時間:2020-11-09 15:55:59 來源:億速云 閱讀:2666 作者:Leah 欄目:開發技術

這篇文章運用簡單易懂的例子給大家介紹java中如何使用ResultSet實現遍歷數據,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

1.查找數據庫中表的列名

<pre name="code" class="html">String sql = "select *from tblmetadatainfo";
 ResultSet rs = MySqlHelper.executeQuery(sql, null);
 String str="";
 try {
  ResultSetMetaData rsmd = rs.getMetaData();
  for (int i = 1; i < rsmd.getColumnCount(); i++) {
  str+=rsmd.getColumnName(i)+",";
  }
  str=str.substring(0, str.length()-1);
 } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }

2.查找數據庫中表中每條記錄的列值

for(int i=1;i<rs.getMetaData().getColumnCount();i++){
   str+=rs.getString(i)+",";
  }

補充知識:Java:使用ResultSet.next()執行含有rownum的SQL語句速度緩慢

在使用Oracle數據庫進行分頁查詢時,經常會用到如下SQL:

select tm.* from (select rownum rm, t.* xmlrecord from testtable t) tm where tm.rm > &#63; and tm.rm <= &#63;

使用的java代碼如下:

int startIdx = 0;
int endIdx = 10000; 
String sql = "select tm.* from (select rownum rm, t.* xmlrecord from testtable t) tm where tm.rm > &#63; and tm.rm <= &#63;";
 
try (Connection conn = dataSource.getConnection(); PreparedStatement ps = conn.prepareStatement(sql);) {
 
 ps.setInt(1, startIdx);
 ps.setInt(2, endIdx);
 
 try (ResultSet rs = ps.executeQuery();) {
 while (rs.next()) {
  String id = rs.getString(2);
 
  System.out.println("id="+id);
 }
 }
}

當使用以上代碼時,會發現當取完最后一條記錄后,再執行rs.next()時,本來希望返回false后跳出循環,但rs.next()會執行非常長的時間。解決的方法是不讓rs.next()來判斷下一條記錄不存在,而在代碼通過計數來實現:

int startIdx = 0;
int endIdx = 10000;
int i = 0;
int count = endIdx - startIdx;
String sql = "select tm.* from (select rownum rm, t.* xmlrecord from testtable t) tm where tm.rm > &#63; and tm.rm <= &#63;";
 
try (Connection conn = dataSource.getConnection(); PreparedStatement ps = conn.prepareStatement(sql);) {
 
 ps.setInt(1, startIdx);
 ps.setInt(2, endIdx);
 
 try (ResultSet rs = ps.executeQuery();) {
  while (rs.next()) {
  i++;
  String id = rs.getString(2); 
  System.out.println("id="+id);
   if(i == count) {
   break;
  }
 }
 }
}

如果代碼中設置了fetchSize,并且fetchSize不能被count整除時,在取最后一片數據時,rs.next()也會執行很長時間:

int startIdx = 0;
int endIdx = 10000; 
String sql = "select tm.* from (select rownum rm, t.* xmlrecord from testtable t) tm where tm.rm > &#63; and tm.rm <= &#63;";
 
try (Connection conn = dataSource.getConnection(); PreparedStatement ps = conn.prepareStatement(sql);) {
 ps.setFetchSize(300);
 ps.setInt(1, startIdx);
 ps.setInt(2, endIdx);
 
 try (ResultSet rs = ps.executeQuery();) {
 
 while (rs.next()) {
  String id = rs.getString(2);
 
  System.out.println("id="+id);
 }
 }
}

以上代碼中,當取得9900條數據后,再取下一個300條時,rs.next()就會執行很長時間,可能是由于取不到一個完整的300條記錄造成的。解決方法是將fetchSize設置成能被count整除的數字,比如:

ps.setFetchSize(500);

在以上兩種狀況下,為什么rs.next()會執行很長時間,還不是很清楚,但可以通過上述方式解決。至于為什么會有這個問題,有知道原因的朋友,請不吝賜教。

關于java中如何使用ResultSet實現遍歷數據就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武威市| 潮安县| 兴仁县| 嘉峪关市| 屏边| 临潭县| 通山县| 延吉市| 石楼县| 上思县| 文水县| 沂南县| 安塞县| 晋中市| 峨眉山市| 清流县| 兰坪| 辛集市| 清镇市| 昌江| 多伦县| 自贡市| 宁夏| 柏乡县| 图木舒克市| 罗源县| 南京市| 黑河市| 霞浦县| 错那县| 兰州市| 神木县| 泸溪县| 武邑县| 惠水县| 新泰市| 保德县| 英吉沙县| 保靖县| 突泉县| 阿坝县|