AppVersionRepo.java 1.1 KB

12345678910111213141516171819202122232425
  1. package com.izouma.nineth.repo;
  2. import com.izouma.nineth.domain.AppVersion;
  3. import org.springframework.data.jpa.repository.JpaRepository;
  4. import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
  5. import org.springframework.data.jpa.repository.Modifying;
  6. import org.springframework.data.jpa.repository.Query;
  7. import javax.transaction.Transactional;
  8. import java.util.Optional;
  9. public interface AppVersionRepo extends JpaRepository<AppVersion, Long>, JpaSpecificationExecutor<AppVersion> {
  10. @Query("update AppVersion t set t.del = true where t.id = ?1")
  11. @Modifying
  12. @Transactional
  13. void softDelete(Long id);
  14. Optional<AppVersion> findByPlatformAndVersionAndChannelAndDelFalse(String platform, String version, String channel);
  15. Optional<AppVersion> findFirstByPlatformAndReviewFalseAndDelFalseOrderByVersionNumDesc(String platform);
  16. @Query(value = "select * from app_version a where a.platform = ?1 and a.channel = ?2 and a.review = false and a.del = false " +
  17. "order by a.version_num desc", nativeQuery = true)
  18. Optional<AppVersion> findLatest(String platform, String channel);
  19. }