Hibernate и JPA @PreUpdate и @PrePersist не работают - PullRequest
0 голосов
/ 03 июня 2019

Я пытаюсь запустить некоторый код непосредственно перед обновлением или сохранением.У меня есть в моей сущности:

@Data
@EqualsAndHashCode(callSuper=false)
@Table(name="file_management", uniqueConstraints = { @UniqueConstraint(columnNames = {"name"})})
@Entity
public class FileManagement {
    @Id
    @GeneratedValue(strategy= GenerationType.IDENTITY)
    private long id;

    @Column(name="name")
    private String name;

    @Column(name = "SEARCH_STRING", length = 1000)
    @Getter @Setter
    private String searchString;

    @PreUpdate
    @PrePersist
    void updateSearchString() {

        final String fullSearchString = StringUtils.join(Arrays.asList(
                name),
                " ");

        this.searchString = StringUtils.substring(fullSearchString, 0, 999);

    }
}

У меня есть в моем FileManagementRepository:

    @Transactional
    @Modifying
    @Query("UPDATE FileManagement SET name = :name WHERE id = :id")
    public void updateFile(long id, String name);

    @Transactional
    @Modifying
    @Query(value = "INSERT INTO file_management (name, filename, created_by, create_date, is_active, is_deleted) VALUES (:name, :filename, :createdBy, :createdDate, :isActive, :isDeleted)", nativeQuery = true)
    public void createFileWithFilename(String name, String filename, String createdBy, Date createdDate, boolean isActive, boolean isDeleted);

и в моем FileManagementService.java

public void updateFileWithFilename(String id, String name) {
        fileManagementRepository.updateFile(Long.parseLong(id), name);
    }
public boolean createFileWithFilename(String name, String filename, String createdBy, Date createdDate, boolean isActive, boolean isDeleted) {
        fileManagementRepository.createFileWithFilename(name, filename, createdBy, createdDate, isActive, isDeleted);
        return true;
    }

Но проблема заключается вМетод updateSearchString () не вызывается при обновлении или вставке новой строки.Столбец search_string (ноль)

Пожалуйста, помогите.Спасибо.

1 Ответ

1 голос
/ 03 июня 2019

Я предполагаю, что сущности, которые таким образом вставляются или обновляются с использованием собственного SQL или JPQL, будут пропускать постоянный контекст, а постоянный контекст не будет ими управлять.Однако @PreUpdate и @PrePersist работают только для сущностей, которые управляются контекстом постоянства, поэтому ваши @PreUpdate и @PrePersist не будут выполняться для них.

Я думаю, вам следует вставить и обновитьсущности более JPA, которые гарантируют, что постоянный контекст будет управлять ими:

@Service
public class FileManagementService{

    @Autowired
    private FileManagementRepository fileManagementRepository;

    @Transactional 
    public void updateFileWithFilename(String id, String name) {
       Optional<FileManagement> file= fileManagementRepository.findById(id);
       if(file.isPresent()){
           file.get().setName(name);
       }else{
          throw new RuntimeException("Record does not exist");
       }
    }

    @Transactional 
    public void createFileWithFilename(String name, String filename, String createdBy, Date createdDate, boolean isActive, boolean isDeleted) {
       FileManagement file= new FileManagement(name,fileName,........);
       fileManagementRepository.save(file);
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...