|
7 | 7 | import org.springframework.stereotype.Repository;
|
8 | 8 | import ubc.pavlab.rdp.model.Taxon;
|
9 | 9 | import ubc.pavlab.rdp.model.UserGene;
|
| 10 | +import ubc.pavlab.rdp.model.Gene; |
10 | 11 | import ubc.pavlab.rdp.model.enums.TierType;
|
11 | 12 |
|
12 | 13 | import javax.persistence.QueryHint;
|
@@ -43,4 +44,18 @@ public interface UserGeneRepository extends JpaRepository<UserGene, Integer> {
|
43 | 44 | @QueryHints(@QueryHint(name = "org.hibernate.cacheable", value = "true"))
|
44 | 45 | Collection<UserGene> findBySymbolContainingIgnoreCaseAndTaxonAndTierIn(String symbolContaining, Taxon taxon, Set<TierType> tiers);
|
45 | 46 |
|
| 47 | + // Return gene IDs of all associations in tiers |
| 48 | + @QueryHints(@QueryHint(name = "org.hibernate.cacheable", value = "true")) |
| 49 | + @Query("select distinct geneId FROM UserGene WHERE tier IN (:tiers)") |
| 50 | + Collection<Integer> findDistinctGeneByTierIn( @Param("tiers") Collection<TierType> tiers ); |
| 51 | + |
| 52 | + // Return the reverse-mapped human gene(s) for a given ortholog target. |
| 53 | + @QueryHints(@QueryHint(name = "org.hibernate.cacheable", value = "true")) |
| 54 | + @Query("select sourceGene FROM Ortholog where targetGene IN (:target_gene) ") |
| 55 | + Collection<Integer> findHumanGenesForTarget(@Param("target_gene") Collection<Integer> targetGene); |
| 56 | + |
| 57 | + // Return all human genes. |
| 58 | + @QueryHints(@QueryHint(name = "org.hibernate.cacheable", value = "true")) |
| 59 | + @Query("select geneId FROM UserGene where taxon = '9606'") |
| 60 | + Collection<Integer> findAllHumanGenes(); |
46 | 61 | }
|
0 commit comments