我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解Java如何判断ResultSet结果集是否为空

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解Java如何判断ResultSet结果集是否为空

问题描述

ResultSet 表示 select 语句的查询结果集。ResultSet 对象具有指向其当前数据行的指针, 最初,指针被置于第一行记录之前,通过 next() 方法可以将指针移动到下一行记录。

next() 方法在 ResultSet 对象没有一行记录时返回 false ,因此可以在 while 循环中使用它来遍历结果集,也可以利用该方法判断结果集是否为空。

示例代码如下:

//此处省略连接数据库的代码...

Statement stmt =conn.createStatement();  
ResultSet  rs     =stmr.executeQuery("select  *  from  Test");

if(rs.next()){  
System.out.println("结果集不为空!");  
}

else{  
System.out.println("结果集为空!");  
}

此时出现第一个坑:Java 的 ResultSet 对象,默认是不可更新的,仅有一个向前移动的指针。

因此,只能遍历它一次,并且只能按从第一行到最后一行的顺序进行。

当你使用了 rs.next() 进行判断后,会出现第一行数据丢失的情况。

这也是我一开始遇到的问题。

深究问题

ResultSet 的 Type 属性

遇到问题后我第一想法是在搜索引擎上搜索相关解决办法,但看了一圈具体有以下“解法”:

调用 rs.last() 方法,以获取 ResultSet中 记录的总数,然后调用 rs.beforeFirst() 方法将光标移回到第一条记录前面

这种方法看上去可行,但当我实际修改后运行,却出现报错

Operation not allowed for a result set of type ResultSet.TYPE_FORWARD_ONLY.

这又是什么原因呢?

出现这个报错的主要原因是:

ResultSet.TYPE_FORWARD_ONLY 类型的 ResultSet 只允许向前遍历,不支持访问先前的记录或确定其大小。因此,使用 last() 和 getRow() 等方法都是不可行。

而 ResultSet 的 Type 属性有如下几种:

参数类型说明
ResultSet.TYPE_FORWORD_ONLY结果集的游标只能向下滚动
ResultSet.TYPE_SCROLL_INSENSITIVE结果集的游标可以上下移动,当数据库变化时,当前结果集不变
ResultSet.TYPE_SCROLL_SENSITIVE返回可滚动的结果集,当数据库变化时,当前结果集同步改变

当 Statement stmt = conn.createStatement(); 中 的 createStatement() 缺省时等价于: createStatement(ResultSet.TYPE_FORWORD_ONLY,ResultSet.CONCUR_READ_ONLY);

也就是结果集的游标只能向下滚动

所以才会出现 Operation not allowed for a result set of type ResultSet.TYPE_FORWARD_ONLY. 的报错

也就是 ResultSet 默认情况下,只能使用 next() 方法向前逐行移动游标,而不支持 last()、first() 以及 absolute() 等方法,如果要使用 last()、absolute() 等方法,必须在由 Connection 生成 Statement 时指定相应的参数,格式如下:

Statement stmt =conn.ctrateStatement(游标类型,记录更新权限);

解决办法

1.手动指定游标类型

Statement stmt =conn.createStatement(ResultSet.TYPE_SCOLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);

2.将 ResultSet 的内容复制到一个 List 中,然后检查 List 是否为空

List<Object[]> results = new ArrayList<>();
while (rs.next()) {
    int columnCount = rs.getMetaData().getColumnCount();
    Object[] row = new Object[columnCount];
    for (int i = 1; i <= columnCount; i++) {
        row[i - 1] = rs.getObject(i);
    }
    results.add(row);
}

if (!results.isEmpty()) {
    // ResultSet不为空,可以执行读取操作
} else {
    // ResultSet为空,不执行读取操作
}

请注意,在实际生产环境中,请考虑数据量和内存使用情况,因为将所有记录复制到List中可能对内存产生很大影响。

3.定义 一个计数变量 i ,每次 next() 则 ++i ,在 while() 循环结束后判断 i 是否小于等于 0

int i = 0;
while (resultSet.next()){
    System.out.println(...);
    ++i;
}
if(i<=0)
    System.out.println(...);

到此这篇关于详解Java如何判断ResultSet结果集是否为空的文章就介绍到这了,更多相关Java判断ResultSet是否为空内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解Java如何判断ResultSet结果集是否为空

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

详解Java如何判断ResultSet结果集是否为空

ResultSet表示select语句的查询结果集。这篇文章主要为大家详细介绍了Java如何判断ResultSet结果集是否为空,感兴趣的可以了解一下
2023-02-10

java如何判断list是否为空?

java判断集合list是否为空的方法:如果想判断list是否为空,可以这么判断:if(list == null || list.size() ==0 ){  //为空的情况}else{  //不为空的情况}list.isEmpty() 和 list.siz
java如何判断list是否为空?
2019-07-11

java如何判断对象是否为空

在Java中,可以使用以下方法来判断一个对象是否为空:1. 使用`==`运算符来判断对象是否为null。如果对象等于null,则表示对象为空。例如:```javaObject obj = null;if (obj == null) {Sys
2023-08-17

java对象如何判断是否为空

在实际书写代码的时候,经常会因为对象为空,而抛出空指针异常java.lang.NullPointerException。下面我们来看一下java中判断对象是否为空的方法:(推荐:java视频教程)首先来看一下工具StringUtils的判断方法:一种是org.
java对象如何判断是否为空
2017-05-08

如何判断java对象是否为空

首先来看一下工具StringUtils的判断方法:一种是org.apache.commons.lang3包下的;另一种是org.springframework.util包下的。这两种StringUtils工具类判断对象是否为空是有差距的:StringUtils
如何判断java对象是否为空
2017-08-03

java如何判断实体类是否为空

在Java中,判断一个实体类是否为空可以根据实体类中的属性是否为null来进行判断。以下是几种常见的判断方式:1. 判断对象是否为null:使用`==`运算符来判断对象是否为null。```javaif (entity == null) {
2023-09-25

Java中如何判断一个对象是否为空

在Java中,可以使用以下几种方法来判断一个对象是否为空:1. 使用 `==` 运算符判断是否为 `null`:通过将对象与 `null` 进行比较,如果相等则表示对象为空。```javaif (object == null) {Syste
2023-09-25

java中如何使用if语句判断字符串是否为空或null

首先,区分空串和null串1、 空串""是长度为0的字符串,它有自己的串长度(0)和内容(空),判断一个字符串为空的方法:if (str.length() == 0);或if (str.equals(""));在线java学习视频教程推荐:java视频教程2、
java中如何使用if语句判断字符串是否为空或null
2018-10-22

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录