Spring Data 删除功能不删除记录

Kih*_*ats 4 java spring querydsl spring-data-jpa spring-boot

我有以下简单的应用程序

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
}
Run Code Online (Sandbox Code Playgroud)

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
}
Run Code Online (Sandbox Code Playgroud)

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
}
Run Code Online (Sandbox Code Playgroud)

UserRoleUserRepository

@Repository
@Transactional
public interface UserRoleUserRepository extends JpaRepository<UserRoleUser, Long>, QueryDslPredicateExecutor<UserRoleUser>{

}
Run Code Online (Sandbox Code Playgroud)

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);
       }

   }

}
Run Code Online (Sandbox Code Playgroud)

在运行main应用程序时,UserRoleUser表中的数据库记录不会被删除。可能是什么问题?我正在使用Spring DataQueryDsl

我也试过将删除功能放在 a 上,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();
    }
}
Run Code Online (Sandbox Code Playgroud)

Kih*_*ats 7

如果您需要使用 提供的给定方法CrudRepository,请使用JpaRepository.deleteInBatch(). 这解决了问题。


loc*_*s2k 6

问题是实体仍然附加并且在它们分离之前不会被删除。如果您按他们的 id 而不是实体本身删除,它将删除它们。

我注意到的一件事是您一次删除一个用户,这可能会导致数据库性能下降,因为每次都会重新创建查询。最简单的方法是将所有 id 添加到一个集合中,然后删除该 id 集合。像这样的东西:

Set<Integer> idList = new HashSet<>();
for (UserRoleUser userRoleUser : findAll) {
  idList.add(userRoleUser.getId());
}

if (!idList.isEmpty()) {
  userRoleUserRepository.delete(idList);
}
Run Code Online (Sandbox Code Playgroud)

然后在您的存储库中添加删除方法

@Modifying
@Query("DELETE FROM UserRoleUser uru WHERE uru.id in ?1")
@Transactional
void delete(Set<Integer> id);
Run Code Online (Sandbox Code Playgroud)