0

私の Web アプリケーションでは、Apache Tomcat (TomEE)/7.0.37 サーバーで OpenJPA を使用しています。Netbeans を使用してクラスを自動生成します (「データベースからのエンティティ クラス...」および「エンティティ クラスからのセッション Bean...」)。

私の User.class:

@Entity
@Table(name = "USER")
@XmlRootElement
@NamedQueries({
@NamedQuery(name = "User.findAll", query = "SELECT u FROM User u"),
@NamedQuery(name = "User.findByIdUser", query = "SELECT u FROM User u WHERE u.idUser = :idUser"),
@NamedQuery(name = "User.findByLogin", query = "SELECT u FROM User u WHERE u.login = :login"),
@NamedQuery(name = "User.findByPassword", query = "SELECT u FROM User u WHERE u.password = :password")})
public class User implements Serializable {
 private static final long serialVersionUID = 1L;


 @Id
 @GeneratedValue(strategy = GenerationType.IDENTITY)
 @Basic(optional = false)
 @NotNull
 @Column(name = "id_user")
 private Short idUser;


 @Size(max = 8)
 @Column(name = "login")
 private String login;
 @Size(max = 64)
 @Column(name = "password")
 private String password;
 @JoinTable(name = "USER_has_ROLES", joinColumns = {
    @JoinColumn(name = "USER_id", referencedColumnName = "id_user")}, inverseJoinColumns = {
    @JoinColumn(name = "ROLES_id", referencedColumnName = "id_roles")})
 @ManyToMany
 private List<Roles> rolesList;
 @OneToMany(cascade = CascadeType.ALL, mappedBy = "user")
 private List<Lecturer> lecturerList;
 @OneToMany(cascade = CascadeType.ALL, mappedBy = "user")
 private List<Student> studentList;

//constructors, getters, setters
}

ManagedBean で新しいユーザーを作成すると:

private void addUser() {
    User user = new User();    
    user.setLogin(registerLog);
    user.setPassword(registerPass);
    Roles r = new Roles();  
    r.setIdRoles(new Short("2"));
    List<Roles> roleList = new ArrayList<Roles>();
    roleList.add(r);        
    user.setRolesList(roleList);    


    userFacade.create(user);  //<------here i create by abstract facade by em.persist(user);

}

私は例外を取得します:

javax.el.ELException: javax.ejb.EJBException: The bean encountered a non-application exception; nested exception is: javax.validation.ConstraintViolationException: A validation constraint failure occurred for class "model.entity.User".

viewId=/pages/register.xhtml
location=/home/jakub/Projekty/Collv2/build/web/pages/register.xhtml
phaseId=INVOKE_APPLICATION(5)

Caused by:
 javax.validation.ConstraintViolationException - A validation constraint failure occurred for class "model.entity.User".
at   org.apache.openjpa.persistence.validation.ValidatorImpl.validate(ValidatorImpl.java:282)

/pages/register.xhtml at line 26 and column 104 action="#{registerController.register}"

ユーザーIDが正しくないようです。なにが問題ですか ?

4

2 に答える 2

0

私はこれをしません:

Roles r = new Roles();  
r.setIdRoles(new Short("2"));
List<Roles> roleList = new ArrayList<Roles>();
roleList.add(r);     

これは基本的に誤用です。このロールが存在し、作成しているユーザーにリンクできる場合は、それを取得して設定する必要があります。それ以外の場合、新しい Role を作成する場合は、 @Id を設定しないでください。OpenJPA が新しい項目を作成する代わりに既存の項目を検索するため、エラーが発生します。

そして、はい、それがあなたのエラーの原因である可能性があります。修正は Role を取得するか、@Id 属性を設定しないことです。さらに、 .setIdRoles() の命名は、私にとって非常に奇妙な命名です。

于 2013-09-24T18:46:33.860 に答える