问题描述
当我检查 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 (将#修改为@)