Java EE 6、EJB 3.1、JPA 2.0 - 在数据库中插入记录时出错

标签 java jpa-2.0 java-ee-6 ejb-3.1

我正在尝试在数据库中插入一条记录(使用 Java EE 6、EJB 3.1、JPA 2.0)。我收到一条错误消息,指出 accountTypeId 字段为空,但我已将其设置为自动生成。谁能建议我做错了什么?

以下是创建表查询:

create table example.account_type(
    account_type_id INT NOT null PRIMARY KEY GENERATED ALWAYS AS IDENTITY (START WITH 1, INCREMENT BY 1),
    account_type_desc varchar(20)
);

以下是实体类:

编辑:更新了 NetBeans 生成的实体类,但该类不起作用。我还添加了 @GenerateValue 注释,但仍然不起作用。

@Entity
@Table(name = "ACCOUNT_TYPE")
@NamedQueries({
    @NamedQuery(name = "AccountType.findAll", query = "SELECT a FROM AccountType a"),
    @NamedQuery(name = "AccountType.findByAccountTypeId", query = "SELECT a FROM AccountType a WHERE a.accountTypeId = :accountTypeId"),
    @NamedQuery(name = "AccountType.findByAccountTypeDesc", query = "SELECT a FROM AccountType a WHERE a.accountTypeDesc = :accountTypeDesc")})
public class AccountType implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)  // ADDED THIS LINE
    @Basic(optional = false)
    @NotNull
    @Column(name = "ACCOUNT_TYPE_ID")
    private Integer accountTypeId;
    @Size(max = 50)
    @Column(name = "ACCOUNT_TYPE_DESC")
    private String accountTypeDesc;

    public AccountType() {
    }

    public AccountType(Integer accountTypeId) {
        this.accountTypeId = accountTypeId;
    }

    public Integer getAccountTypeId() {
        return accountTypeId;
    }

    public void setAccountTypeId(Integer accountTypeId) {
        this.accountTypeId = accountTypeId;
    }

    public String getAccountTypeDesc() {
        return accountTypeDesc;
    }

    public void setAccountTypeDesc(String accountTypeDesc) {
        this.accountTypeDesc = accountTypeDesc;
    }

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (accountTypeId != null ? accountTypeId.hashCode() : 0);
        return hash;
    }

    @Override
    public boolean equals(Object object) {
        // TODO: Warning - this method won't work in the case the id fields are not set
        if (!(object instanceof AccountType)) {
            return false;
        }
        AccountType other = (AccountType) object;
        if ((this.accountTypeId == null && other.accountTypeId != null) || (this.accountTypeId != null && !this.accountTypeId.equals(other.accountTypeId))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "Entities.AccountType[ accountTypeId=" + accountTypeId + " ]";
    }

}

以下是 session bean接口(interface):

@Remote
public interface AccountTypeSessionBeanRemote {
    public void createAccountType();
    public void createAccountType(String accDesc);
}

下面是 session bean的实现类:

@Stateless
public class AccountTypeSessionBean implements AccountTypeSessionBeanRemote {
    @PersistenceContext(unitName="ExamplePU")
    private EntityManager em;

    @Override
    public void createAccountType(String accDesc) {
        AccountType emp = new AccountType(accDsc);
       try {
           this.em.persist(emp);
           System.out.println("after persist");
       } catch(Exception ex) {
           System.out.println("ex: " + ex.getMessage());
       }
    }
}

以下是主类:

public class Main {
    @EJB
    private static AccountTypeSessionBeanRemote accountTypeSessionBean;

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        accountTypeSessionBean.createAccountType("test");
    }
}

错误如下:

INFO: ex: Object: Entities.AccountType[ accountTypeId=null ] is not a known entity type.

最佳答案

您不会因为“accountTypeId 字段为空”而收到错误。正如错误消息所述,发生错误是因为“Entities.AccountType[ accountTypeId=null ] 不是已知的实体类型”。

最可能的原因是 AccountType 没有用 @Entity 进行注释。 。这个问题很可能通过添加它来解决。此外,使用

是有意义的
@GeneratedValue(strategy = GenerationType.IDENTITY)

而不是自动。自动意味着提供者根据目标数据库的能力选择策略。根据表定义,显然首选策略是 IDENTITY。

关于Java EE 6、EJB 3.1、JPA 2.0 - 在数据库中插入记录时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11912002/

相关文章:

java - 间接 Hibernate/JPA 方法调用丢失事务

java - JBoss 中带注释的 WS

java - JPA 的 EntityManager 应该是 RequestScoped 吗?

java - JPA 2 中仅基于一个纯字符串的孤立删除

Spring 3、Java EE 6

java - 我在哪里可以配置 Java EE 6 中@Asynchronous 调用背后的线程池?

java - 是否有正确的方法让 util 方法找到测试资源路径?

java - 通过字符串引用id android

java - 如何在不更改操作系统用户名的情况下更改 IntelliJ IDEA 中的 ${USER} 变量?

java - 如何在 Controller 中制作删除按钮