JavaEE6、EJB3.1、JPA2.0-在数据库中插入记录时出错
我试图在数据库中插入一条记录(使用JavaEE6、EJB3.1、JPA2.0)。我收到一个错误,accountTypeId字段为空,但我已将其设置为自动生成。谁能告诉我我做错了什么 以下是创建表查询:JavaEE6、EJB3.1、JPA2.0-在数据库中插入记录时出错,java,jpa-2.0,java-ee-6,ejb-3.1,Java,Jpa 2.0,Java Ee 6,Ejb 3.1,我试图在数据库中插入一条记录(使用JavaEE6、EJB3.1、JPA2.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), acco
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生成的实体类,但该类不起作用。我还添加了@GeneratedValue注释,但仍然不起作用
@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 + " ]";
}
}
以下是会话bean接口:
@Remote
public interface AccountTypeSessionBeanRemote {
public void createAccountType();
public void createAccountType(String accDesc);
}
以下是会话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
没有用注释。这个问题可以通过添加它来解决。此外,使用
@GeneratedValue(strategy = GenerationType.IDENTITY)
而不是自动。自动意味着提供者根据目标数据库的功能选择策略。根据表定义,显然首选策略是标识。我将我的
创建表查询更改如下:
create table example.account_type(
account_type_id INT NOT null PRIMARY KEY,
account_type_desc varchar(20)
);
然后必须向实体类添加以下行(Netbeans没有添加该行):
缺少的实体注释可能只是被剪切和粘贴,但是是的,如果没有,它应该在那里。但我认为你的第二个答案,GenerationType.IDENTITY,可能是根本原因。谢谢大家的回答。缺少的@Entity注释只是一个复制粘贴错误。我试图将generationtype更改为identity,但没有成功。我仍然会犯同样的错误。
@GeneratedValue(strategy = GenerationType.AUTO)