0

我不知道为什么尽管事务回滚,但我的可嵌入对象列表仍然存在于数据库中。

我的实体用户具有可嵌入角色列表。

当我使用与数据库中已有的用户名相同的用户名持久化用户时,我看到一个异常:“RollbackException:无法提交:事务标记为回滚”,这很好,因为我有唯一的用户名列。但我不知道为什么,尽管回滚,该用户的角色列表仍然存在于数据库中。

就像事务仅适用于实体类,并且每次都将嵌入式角色列表保存到数据库,即使它不应该(因为回滚)。

我究竟做错了什么 ?感谢您的任何提示(我使用的是 OpenJPA 2.3.0)

用户代码:

@Entity
public class User {

   @Id
   @GeneratedValue(strategy = GenerationType.IDENTITY)
   private int id;

   @Column(unique = true, nullable = false)
   private String username;

   @ElementCollection(fetch = FetchType.LAZY)
   @CollectionTable(
           name = "ROLES",
           joinColumns = @JoinColumn(name = "OWNER_ID")
   )
   private List<Role> roles;

   private String password;
   private boolean enabled;

   public User(String username, String password) {
       this.username = username;
       this.password = password;
       this.enabled = true;
       roles = new ArrayList<Role>();

       Role userrole = new Role();
       userrole.setRole("ROLE_USER");
       userrole.setUsername(username);
       roles.add(userrole);
   }
   //getters and setters
}

角色代码:

@Embeddable
public class Role {


    @Column(name="username")
    String username;
    @Column(name="userrole")
    String role;
     //getters and setters
}
4

0 回答 0