我有两个实体 User
以及 Role
. 一个用户可以有多个角色,每个角色可以与多个用户关联。i、 例如,用户角色有很多关系
例如:用户ram、rob和john是管理员
我正在用户和角色之间创建一个连接表来存储信息。
@Entity
@Table(name = "account")
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Account {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "user_id")
private int id;
@Column(unique = true)
private String username;
@Transient
@JsonIgnore
private String password;
@ManyToMany(fetch = FetchType.EAGER,cascade = CascadeType.)
@JoinTable(name = "user_role", joinColumns = @JoinColumn(name = "user_id"), inverseJoinColumns = @JoinColumn(name = "role_id"))
private Set<Role> roles;
@Column
private boolean deleted;
}
和role.java
@Entity
@Table(name = "role")
@Data
public class Role {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name="role_id")
private int id;
@Column(name="role",unique=true)
private String role;
}
在spring boot中执行此操作时,将创建以下表: account
, user_role
, role
.
因为我的角色数量是固定的。我手动插入的
INSERT INTO `role` VALUES (1,'ADMIN');
INSERT INTO `role` VALUES (2,'USER');
现在,从我的javaspring启动应用程序开始,我尝试在account表中插入一个新条目。尝试在中插入新条目 Role
还有table。。。我只想把这个插进去 account
以及 user_role
表,但不在 role
表格。。。
有人能告诉我怎么做吗?
更新:
这里是账户插入部分(创建账户代码段)
//创建帐户
public Account createAccount(AccountDto account) {
Account newAccount = new Account();
newAccount.setPassword(account.getPassword());
newAccount.setUsername(account.getUsername());
Set<Role> roles = new HashSet<Role>();
Role role = new Role();
role.setRole(account.getRole());
roles.add(role);
newAccount.setRoles(roles);
Account savedAccount = save(newAccount);
return savedAccount;
}
//更新帐户
public Account updateAccount(String oldUserName, AccountDto accountDto) {
Account account = accountRepository.findByUsername(oldUserName);
if (account != null) {
Set<Role> roleset = new HashSet<Role>();
if(accountDto.getRole() != null && !accountDto.getRole().isEmpty()){
Role role = roleRepository.findByRole(accountDto.getRole());
if (role == null) {
roleset.add(role);
}
}
account.setRoles(roleset);
account.setUsername(accountDto.getUsername());
account = accountRepository.save(account);
return account;
} else
return null;
}
1条答案
按热度按时间o2g1uqev1#
尝试在account类中编译cascadetype。
您还需要为帐户实体添加链接。
你可以在这里找到很好的教程https://www.callicoder.com/hibernate-spring-boot-jpa-many-to-many-mapping-example/