热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java返回int型的空值,从JavaResu检查nullint值

从JavaResu检查nullint值在Java中,我试图从ResultSet中测试一个空值,其中列被转换为原始int类型。intiVal;Result

从Java Resu检查null int值

在Java中,我试图从ResultSet中测试一个空值,其中列被转换为原始int类型。

int iVal;

ResultSet rs = magicallyAppearingStmt.executeQuery(query);

if (rs.next()) {

if (rs.getObject("ID_PARENT") != null && !rs.wasNull()) {

iVal = rs.getInt("ID_PARENT");

}

}

从上面的代码片段,有更好的方法来做到这一点,我假设第二个isNull()测试是多余的?

教育我们,谢谢

ian_scho asked 2019-03-03T17:21:58Z

9个解决方案

305 votes

当字段值为NULL时,iVal的默认值是返回0,这也是iVal声明的默认值。 在这种情况下,您的测试完全是多余的。

如果你真的想要做一些不同的事情,如果字段值是NULL,我建议:

int iVal = 0;

ResultSet rs = magicallyAppearingStmt.executeQuery(query);

if (rs.next()) {

iVal = rs.getInt("ID_PARENT");

if (rs.wasNull()) {

// handle NULL field value

}

}

(编辑为@martin评论如下;编写的OP代码无法编译,因为iVal未初始化)

Richard answered 2019-03-03T17:22:23Z

72 votes

另一种方案:

public class DaoTools {

static public Integer getInteger(ResultSet rs, String strColName) throws SQLException {

int nValue = rs.getInt(strColName);

return rs.wasNull() ? null : nValue;

}

}

Patrice IMBERT answered 2019-03-03T17:22:43Z

26 votes

我认为,这是多余的。 rs.getObject("ID_PARENT")应返回Integer对象或null,如果列值实际为NULL.所以甚至应该可以执行以下操作:

if (rs.next()) {

Integer idParent = (Integer) rs.getObject("ID_PARENT");

if (idParent != null) {

iVal = idParent; // works for Java 1.5+

} else {

// handle this case

}

}

Andreas_D answered 2019-03-03T17:23:11Z

20 votes

只需检查字段是否为ResultSet#getObject()或不使用ResultSet#getObject()。用您想要的任何空值大小替换Integer。

int foo = resultSet.getObject("foo") != null ? resultSet.getInt("foo") : -1;

或者,如果您可以保证使用正确的DB列类型,以便ResultSet#getObject()确实返回Integer(因此不是Long,Short或Byte),那么您也可以将其类型转换为Integer。

Integer foo = (Integer) resultSet.getObject("foo");

BalusC answered 2019-03-03T17:23:46Z

8 votes

你可以简单地使用AFAIK

iVal = rs.getInt("ID_PARENT");

if (rs.wasNull()) {

// do somthing interesting to handle this situation

}

即使它是NULL。

Peter Tillemans answered 2019-03-03T17:24:21Z

1 votes

为方便起见,您可以在ResultSet周围创建一个包装类,当ResultSet通常不会返回空值时返回空值。

public final class ResultSetWrapper {

private final ResultSet rs;

public ResultSetWrapper(ResultSet rs) {

this.rs = rs;

}

public ResultSet getResultSet() {

return rs;

}

public Boolean getBoolean(String label) throws SQLException {

final boolean b = rs.getBoolean(label);

if (rs.wasNull()) {

return null;

}

return b;

}

public Byte getByte(String label) throws SQLException {

final byte b = rs.getByte(label);

if (rs.wasNull()) {

return null;

}

return b;

}

// ...

}

Jacob Crofts answered 2019-03-03T17:24:49Z

1 votes

只是Java Generics的更新。

您可以创建一个实用程序方法,以从先前生成的给定ResultSet中检索任何Java类型的可选值。

不幸的是,getObject(columnName,Class)不返回null,而是返回给定Java类型的默认值,因此需要2次调用

public T getOptionalValue(final ResultSet rs, final String columnName, final Class clazz) throws SQLException {

final T value = rs.getObject(columnName, clazz);

return rs.wasNull() ? null : value;

}

在此示例中,您的代码可能如下所示:

final Integer columnValue = getOptionalValue(rs, Integer.class);

if (columnValue == null) {

//null handling

} else {

//use int value of columnValue with autoboxing

}

很高兴得到反馈

luchoct answered 2019-03-03T17:25:45Z

0 votes

使用java 8,您可以这样做:

Long nVal = Optional.ofNullable(resultSet.getBigDecimal("col_name"))

.map(BigDecimal::longValue).orElse(null));

在这种情况下,如果SQL值为NULL,则确保nVal为空(而不是零)

George answered 2019-03-03T17:26:21Z

-5 votes

如果您控制SQL,另一种检查的好方法是在int列的查询本身中添加一个默认值。 然后检查该值。

例如,对于Oracle数据库,请使用NVL

SELECT NVL(ID_PARENT, -999) FROM TABLE_NAME;

然后检查

if (rs.getInt('ID_PARENT') != -999)

{

}

当然,这也是假设存在通常在列中找不到的值。

Chris answered 2019-03-03T17:27:10Z



推荐阅读
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 在 Flutter 开发过程中,开发者经常会遇到 Widget 构造函数中的可选参数 Key。对于初学者来说,理解 Key 的作用和使用场景可能是一个挑战。本文将详细探讨 Key 的概念及其应用场景,并通过实例帮助你更好地掌握这一重要工具。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • MySQL DateTime 类型数据处理及.0 尾数去除方法
    本文介绍如何在 MySQL 中处理 DateTime 类型的数据,并解决获取数据时出现的.0尾数问题。同时,探讨了不同场景下的解决方案,确保数据格式的一致性和准确性。 ... [详细]
  • 在Java中,this是一个引用当前对象的关键字。如何通过this获取并显示其所指向的对象的属性和方法?本文详细解释了this的用法及其背后的原理。 ... [详细]
  • 20100423:Fixes:更新批处理,以兼容WIN7。第一次系统地玩QT,于是诞生了此预备式:【QT版本4.6.0&#x ... [详细]
  • 本文探讨了在Java多线程环境下,如何确保具有相同key值的线程能够互斥执行并按顺序输出结果。通过优化代码结构和使用线程安全的数据结构,我们解决了线程同步问题,并实现了预期的并发行为。 ... [详细]
  • 本文介绍如何使用Perl编写一个简单的爬虫,从丁香园网站获取意大利的新冠病毒感染情况。通过LWP::UserAgent模块模拟浏览器访问并解析网页内容,最终提取所需数据。 ... [详细]
  • 解决C++编译错误C3867的方法
    本文详细介绍了在不同版本的Visual Studio中,如何正确处理成员函数指针以避免编译错误C3867。同时,提供了一个具体的代码示例及其优化方案。 ... [详细]
  • 本文详细介绍了Java中的输入输出(IO)流,包括其基本概念、分类及应用。IO流是用于在程序和外部资源之间传输数据的一套API。根据数据流动的方向,可以分为输入流(从外部流向程序)和输出流(从程序流向外部)。此外,还涵盖了字节流和字符流的区别及其具体实现。 ... [详细]
  • 本文介绍如何在PostgreSQL数据库中正确插入和处理JSON数据类型,确保数据完整性和避免常见错误。 ... [详细]
  • 本文将深入探讨如何在不依赖第三方库的情况下,使用 React 处理表单输入和验证。我们将介绍一种高效且灵活的方法,涵盖表单提交、输入验证及错误处理等关键功能。 ... [详细]
  • 本文详细探讨了 Django 的 ORM(对象关系映射)机制,重点介绍了其如何通过 Python 元类技术实现数据库表与 Python 类的映射。此外,文章还分析了 Django 中各种字段类型的继承结构及其与数据库数据类型的对应关系。 ... [详细]
  • 创建项目:Visual Studio Online 入门指南
    本文介绍如何使用微软的 Visual Studio Online(VSO)创建和管理开发项目。作为一款基于云计算的开发平台,VSO 提供了丰富的工具和服务,简化了项目的配置和部署流程。 ... [详细]
  • 探讨如何从数据库中按分组获取最大N条记录的方法,并分享新年祝福。本文提供多种解决方案,适用于不同数据库系统,如MySQL、Oracle等。 ... [详细]
author-avatar
九育
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有