inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[초급] 맛보자! 코틀린과 스프링으로 API 호출하기

4.10. 검색어 순위 추가하기

findTop10ByOrderByCntDesc 함수의 동작 원리에 대한 질문

339

김정훈

작성한 질문수 1

0

interface WordRepository :CrudRepository<WordCount, String>
{
    fun findTop10ByOrderByCntDesc() :List<WordCount>
}

위 findTop10ByOrderByCntDesc 함수는 선언만 되고 실제 구현이 안되어서 CrudRepository 에도 들어가봤지만 virtual 함수도 아닌걸로 보이는데요..

예상하는 바는 repository에서 함수명을 query로 자동 변환하여 가져오는 형식으로 느껴집니다.

만약 그렇다면, 이 것은 원래 springframework 기능인 것인가요? (완전 웹개발 초보라서 이렇게 문의드립니다...)

spring kotlin spring-boot

답변 1

1

김대디

안녕하세요.

김정훈님 질문 남겨주셔서 감사합니다.

 

질문하신 함수(메서드)들을 Query Methods 라고 합니다.

이것은 Spring Data JPA에 포함되어 있는 기능인데요.

 

Repository interface에 메소드 명으로 query를 자동으로 생성해줍니다.

fun findTop10ByOrderByCntDesc() :List<WordCount>

이렇게 되어있는 메소드 명은 아래의 SQL 만들어서 호출 시 사용하게 됩니다.

select
    w1_0.word,
    w1_0.cnt 
from
    wordcount w1_0 
order by
    w1_0.cnt desc limit ?

 

Query Methods도 JPA에서 좀 더 쉽게 Query를 사용하기 위한 방법이여서 작성 규칙이 있습니다.

아래의 레퍼런스 확인하시면 작성법 학습 하실 수 있습니다.

https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#jpa.query-methods

 

보시고 더 궁금하신 내용 있으시면 질문 남겨주세요 :)

0

김정훈

문서 링크까지 친절하게 답변해주셔서 감사합니다!

혹시 수업자료는 다운받을 수 있는 곳이 없나요?

0

8

2

여러 파드 환경에서 단일 실행 보장 방식

0

11

2

훅 내용 안뜸 오류

0

23

2

챗봇 기능 구체화 (RAG)

0

26

2

패키지 구분에 대해 궁금한게 있습니다

0

20

2

스프링부트 서버 에러나요

0

23

1

코드 자료

0

42

2

2026.04에 추가된 강의 시청 불가

0

33

1

Service Create/Update Record 운용과 Delete Record 미운용의 차이 질문

0

25

1

인가 코드 발급(프론트 vs 백)

0

30

2

인텔리제이 MCP 서버 설정 관련

0

34

2

조회속도 개선에서 더 개선하는 방법이 궁금합니다.

0

35

2

Sequence 관련 질문

1

33

2

Image Only Query

1

30

2

servlet과 container에 대한 질문입니다

0

27

1

프롬프트, 스킬, sub-agent

0

34

1

Required request body is missing

0

5458

2

build.gradle.kts 오류가 발생해요

0

2771

2

BlogDto.decompiled.java 파일 보는법

0

593

2

intellij와 openjdk-17의 연동에 문제가 있는것 같습니다.

0

1784

1

오류를 모르겠습니다

0

509

2

최신 버전의 Spring WebFlux 에서는 reactive 가 없나봐요

0

933

1

use-new-id-generator-mappings

0

2122

1

질문

0

306

1