1.查找数据库中表的列名

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

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 > ? and tm.rm <= ?

使用的java代码如下:

int startIdx = 0;

int endIdx = 10000;

String sql = "select tm.* from (select rownum rm, t.* xmlrecord from testtable t) tm where tm.rm > ? and tm.rm <= ?";

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 > ? and tm.rm <= ?";

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 > ? and tm.rm <= ?";

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遍历数据操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

mysql遍历resultset_java中ResultSet遍历数据操作相关推荐

  1. c++ 删除二叉树的子树_数据结构—树|二叉树|前序遍历、中序遍历、后序遍历【图解实现】...

    点击蓝字关注我们 AI研习图书馆,发现不一样的精彩世界 数据 结构 二叉树的遍历 一.树 在谈二叉树的知识点之前,我们首先来看一下树和图的基本概念.树:不包含回路的连通无向图,树是一种简单的非线性结构 ...

  2. MFC二叉树可视化绘制 (C++)—— 插入、删除、先序遍历、中序遍历、后序遍历、层序遍历(基于平衡二叉树实现)

    界面展示: 相关文章目录 平衡二叉树的构造过程图解 C/C++平衡二叉树实现 -- 插入.删除.先序遍历.中序遍历.后序遍历.层序遍历(设计详解) MFC 在对话框中绘制图形的方法 -- 及二叉树绘制 ...

  3. 通过前序遍历和中序遍历构建二叉树 python实现

    前言 通过前序遍历和中序遍历构建二叉树的原理,主要是找前序遍历根节点在中序遍历中的位置,然后将二叉树而成左子树和右子树,然后依次进行这样的操作,思路还是比较简单的 代码 class Node:def ...

  4. python实现二叉树遍历(前序遍历、中序遍历、后序遍历)

    python实现二叉树遍历(前序遍历.中序遍历.后序遍历) 在计算机科学中,二叉树是一种树数据结构,其中每个节点最多有两个子节点,称为左子节点和右子节点.使用集合理论概念的递归定义是(非空)二叉树是元 ...

  5. 二叉树的创建、前序遍历、中序遍历、后序遍历

    二叉树的创建.前序遍历.中序遍历.后序遍历 // BTree.cpp : Defines the entry point for the console application. /*  作者:成晓旭 ...

  6. 2018.7.28 二叉树的遍历规则(前序遍历、后序遍历、中序遍历)

    树的遍历顺序大体分为三种:前序遍历(先根遍历.先序遍历),中序遍历(中根遍历),后序遍历(后根遍历). 前序遍历:前序遍历可以记为根左右,若二叉树为空,则结束返回. 前序遍历的规则:(1)访问根节点( ...

  7. 根据前序遍历和[中序遍历]

    根据前序遍历和[中序遍历] 1. 递归法: 先序遍历:根节点→左子树→右子树. 中序遍历:左子树→根节点→右子树. 后续遍历:左子树→右子树→根节点. 根据前序遍历和中序遍历建立二叉树,根据以上性质可 ...

  8. 二叉树的前序遍历、中序遍历、后序遍历

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 为什么需要树这种数据结构 树的常用术语 二叉树的概念 二叉树遍历的说明 实现二叉树 实现二叉树的遍历 二叉树查找结点 二叉树 ...

  9. 二叉树,二叉树的归先序遍历,中序遍历,后序遍历,递归和非递归实现

    二叉树,二叉树的归先序遍历,中序遍历,后序遍历,递归和非递归实现 提示:今天开始,系列二叉树的重磅基础知识和大厂高频面试题就要出炉了,咱们慢慢捋清楚! 文章目录 二叉树,二叉树的归先序遍历,中序遍历, ...

最新文章

  1. 【Python】12、字典的实现
  2. python哪里下载import包-详解python中的模块及包导入
  3. 宝塔面板php日志在哪里,宝塔面板怎么查看网站日志?
  4. 图解ARP协议(四)代理ARP原理与实践(“善意的欺骗”)
  5. Ocelot简易教程(七)之配置文件数据库存储插件源码解析
  6. python3seek_Python seek()和tell()函数详解
  7. 欲求不满之 Redis Lua 脚本的执行原理
  8. css样式,后代选择器
  9. 实现用户裂变的5大原则
  10. 大学平均绩点计算器_申请韩国名校绩点是不是万能的?
  11. ALGO-84 大小写转换
  12. 《玩转Django2.0》读书笔记-编写URL规则
  13. 爬虫:python爬虫学习笔记之网站保持登录机制及简单验证码处理
  14. html中给select下拉框赋值
  15. 阿克曼函数实现(Java代码)
  16. 渗透测试基础总结(脚本小子)
  17. Linux排查CPU使用率100%
  18. Python技术练习------自动化处理费用表
  19. 考研数学复习笔记——行列式1
  20. 中国移动发布物联网操作系统 OneOS

热门文章

  1. antd-pro v5版本的tab页签最简实践
  2. 【华为机试】GPU算力问题
  3. vue滚动到底部,自动加载更多
  4. (Erlang语言)运行时中的无锁队列及其在异步线程中的应用
  5. 学计算机的需不需要考研?看完就明白了
  6. 【拿来就能用】C#指定打印机打印的类
  7. elementui菜单下拉样式修改
  8. 网站域名绑定与ICP备案
  9. 把本地厂库提交到远程厂库
  10. linux cpu内存磁盘使用情况查询 python日志打印 ssh连接 scp文件传输 nohup后台运行 环境变量