【发布时间】:2018-07-02 02:23:21
【问题描述】:
我有以下简单的应用程序
Users实体
@Entity
public class Users implements Serializable {
@Id
@GeneratedValue
private long id;
private String name;
@OneToMany(mappedBy = "user", fetch = FetchType.EAGER, cascade = {CascadeType.ALL})
private Set<UserRoleUser> userRoleUser;
// GETTERS AND SETTERS
}
UserRole实体
@Entity
public class UserRole implements Serializable {
@Id
@GeneratedValue
private long id;
private String roleName;
@OneToMany(mappedBy = "userrole", fetch = FetchType.LAZY, cascade = CascadeType.ALL)
private Set<UserRoleUser> userRoleUser;
// GETTERS AND SETTERS
}
UserRoleUser多对多解析器类
@Entity
public class UserRoleUser implements Serializable {
@Id
@GeneratedValue
private long id;
@ManyToOne
@JoinColumn(name = "fk_userId")
private Users user;
@ManyToOne
@JoinColumn(name = "fk_userroleId")
private UserRole userrole;
// GETTERS AND SETTERS
}
UserRoleUserRepository
@Repository
@Transactional
public interface UserRoleUserRepository extends JpaRepository<UserRoleUser, Long>, QueryDslPredicateExecutor<UserRoleUser>{
}
主Application 类
@SpringBootApplication
@Configuration
public class Application {
public static void main(String[] args) {
ConfigurableApplicationContext context = SpringApplication.run(Application.class, args);
UserRoleUserRepository userRoleUserRepository = context.getBean(UserRoleUserRepository.class);
Iterable<UserRoleUser> findAll = userRoleUserRepository.findAll(QUserRoleUser.userRoleUser.id.gt(0));
for (UserRoleUser userRoleUser : findAll) {
userRoleUserRepository.delete(userRoleUser);
}
}
}
在运行main 应用程序时,UserRoleUser 表中的数据库记录不会被删除。可能是什么问题?我正在使用Spring Data 和QueryDsl。
我也尝试将删除功能放在Controller 上,但仍然不起作用。
@RestController
@RequestMapping("/api")
public class DeleteController {
@Autowired
UserRoleUserRepository userRoleUserRepository;
@GetMapping("/delete")
public String delete() {
Iterable<UserRoleUser> findAll = userRoleUserRepository.findAll(QUserRoleUser.userRoleUser.id.gt(0));
for (UserRoleUser userRoleUser : findAll) {
userRoleUserRepository.delete(userRoleUser);
}
return new Date().toString();
}
}
【问题讨论】:
-
如果你的代码正常运行到main方法结束,那么可能是因为你把
@Transactional放在了UserRoleUserRepository接口上。看到这个帖子:stackoverflow.com/questions/5551541/…El Guapo的答案。 -
其实我只是在尝试放
@Transactional注解的时候,因为不管有没有它都不会删除记录。 -
可能是因为为了有效地删除您应该首先从父类中的 Set
userRoleUser 中删除不需要的元素,然后继续删除?
标签: java spring spring-boot spring-data-jpa querydsl