获取 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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...