Я пытаюсь запустить некоторый код непосредственно перед обновлением или сохранением.У меня есть в моей сущности:
@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 (ноль)
Пожалуйста, помогите.Спасибо.