如何解决获取 NullPointerException 检查 Long 数据类型是否为空,然后尝试设置 Long 值
当我检查 Long 值是否为空,然后尝试将值最初设置为 1(如果它为空)(作为序列计数器)时,我当前收到 NullPointerException,否则我将设置该值(@Id 为我的持久性实体 bean 为 1,然后调用 sql max(id) 并将其递增 1。这是我自己的计数器序列逻辑,我正在维护。
我不确定为什么会收到此错误。我的实体 bean 的其他值是从 POJO bean 设置的,实体 Id 除外。下面是我用于设置 Id 以及其他实体设置方法以及实体 bean 的代码:
实体 Bean 类:
@Entity
@Table(name = "PROMO")
public class InsertPromoData {
@Id
@Column(name="SEQ_NUM")
Long id;
@Column(name="ITEM")
String item;
@Column(name="LOC")
String loc;
//getters and setters
}
设置从 POJO 到实体的值:
promo.forEach(record -> {
try {
int sequenceCount = OracleImpl.getMaxSequenceNum().intValue() + 1;
int firstSeqNum = 1;
InsertPromoData insertData = new InsertPromoData();
if (!(insertData.getId() == null)) {
insertData.setId(new Long(sequenceCount));
}
else {
insertData.setId(new Long(firstSeqNum));
}
sequenceCount++;
insertData.setItem(record.getItem());
insertData.setLoc(record.getLoc());
insertPromos.add(insertData);
}
catch (Exception e) {
logger.error("Error with setting insertPromolist from promo list values and the error is " + e.getMessage());
}
}
}
当我在数据库中有记录时,我的 getMaxSequenceNum() 方法有效,但当表中没有记录时就会崩溃。这可能是什么原因,为什么在检查 null 时会收到 NullPointerException?任何建议表示赞赏。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。