Interface ApplicationDAO

All Superinterfaces:
org.springframework.data.repository.CrudRepository<ApplicationEntity,Long>, org.springframework.data.jpa.repository.JpaRepository<ApplicationEntity,Long>, org.springframework.data.repository.ListCrudRepository<ApplicationEntity,Long>, org.springframework.data.repository.ListPagingAndSortingRepository<ApplicationEntity,Long>, org.springframework.data.repository.PagingAndSortingRepository<ApplicationEntity,Long>, org.springframework.data.repository.query.QueryByExampleExecutor<ApplicationEntity>, org.springframework.data.repository.Repository<ApplicationEntity,Long>

@Component public interface ApplicationDAO extends org.springframework.data.jpa.repository.JpaRepository<ApplicationEntity,Long>
  • Method Summary

    Modifier and Type
    Method
    Description
     
    org.springframework.data.domain.Page<FavoriteApplicationEntity>
    findFavoriteAndMandatoryApplications(String userName, org.springframework.data.domain.Pageable pageable)
     
    default List<Long>
     
    default List<Long>
     
    getApplicationIds(String keyword, org.springframework.data.domain.Sort sort)
     
    getApplicationIds(org.springframework.data.domain.Sort sort)
     
     

    Methods inherited from interface org.springframework.data.repository.CrudRepository

    count, delete, deleteAll, deleteAll, deleteAllById, deleteById, existsById, findById, save

    Methods inherited from interface org.springframework.data.jpa.repository.JpaRepository

    deleteAllByIdInBatch, deleteAllInBatch, deleteAllInBatch, deleteInBatch, findAll, findAll, flush, getById, getOne, getReferenceById, saveAllAndFlush, saveAndFlush

    Methods inherited from interface org.springframework.data.repository.ListCrudRepository

    findAll, findAllById, saveAll

    Methods inherited from interface org.springframework.data.repository.ListPagingAndSortingRepository

    findAll

    Methods inherited from interface org.springframework.data.repository.PagingAndSortingRepository

    findAll

    Methods inherited from interface org.springframework.data.repository.query.QueryByExampleExecutor

    count, exists, findAll, findBy, findOne
  • Method Details

    • findBySystemIsTrueAndUrl

      List<ApplicationEntity> findBySystemIsTrueAndUrl(String url)
    • getApplicationIds

      @Query("SELECT app.id FROM ApplicationEntity app\n") List<Long> getApplicationIds(org.springframework.data.domain.Sort sort)
    • getApplicationIds

      default List<Long> getApplicationIds()
    • getApplicationIds

      @Query("SELECT app.id FROM ApplicationEntity app\nWHERE LOWER(app.title) LIKE %?1%\nOR LOWER(app.description) like %?1%\nOR LOWER(app.url) LIKE %?1%\nORDER BY LOWER(app.title)\n") List<Long> getApplicationIds(String keyword, org.springframework.data.domain.Sort sort)
    • getApplicationIds

      default List<Long> getApplicationIds(String keyword)
    • getSystemApplicationIds

      @Query("SELECT app.id FROM ApplicationEntity app\nWHERE app.system = TRUE\n") List<Long> getSystemApplicationIds()
    • findFavoriteAndMandatoryApplications

      @Query("SELECT new FavoriteApplicationEntity(favoriteApp.id, app, favoriteApp.userName, favoriteApp.order, favoriteApp.favorite)\nFROM ApplicationEntity app\nLEFT JOIN FavoriteApplicationEntity favoriteApp\nON app.id = favoriteApp.application.id AND favoriteApp.userName = :userName\nWHERE app.active = TRUE\nAND (\n app.isMandatory = TRUE\n OR (favoriteApp.id IS NOT NULL AND favoriteApp.favorite = TRUE)\n OR (favoriteApp.id IS NULL AND app.isDefault = TRUE)\n)\nORDER BY favoriteApp.order NULLS LAST, app.order NULLS LAST, app.isMandatory DESC\n") org.springframework.data.domain.Page<FavoriteApplicationEntity> findFavoriteAndMandatoryApplications(@Param("userName") String userName, org.springframework.data.domain.Pageable pageable)