SQL where 문 vs Java stream filter 성능차이에 관한 질문입니다
1629
작성한 질문수 11
안녕하세요!
항상 강의 잘 듣고있습니다:)
스프링 관련해서 프로젝트를 하다가
두 지점사이의 거리를 계산하는 쿼리를 짤 일이 생겼습니다.
(예: 내 위치에서 반경 5km이내에 있는 장소들을 가져오기 등)
그래서 QueryDsl 이나 Jdbc Template 으로 SQL 내장 함수를 호출하여 만들려고 했는데
제 경우에는 각 장소의 위경도가 암호화 되어있고 이걸 복호화 해서 거리계산 해야하는데 쉽지않더라고요ㅠㅠ
그래서 문득 생각해보니 이 기능은 전체 데이터를 가져온 다음 차라리 자바 코드로 필터링 하면 더 코드짜기 쉽지 않을까 하는 생각이 들었습니다.
[질문]
DB SQL where 로 필터링 해서 가져오는 것과 자바코드로 필터링 하는 것 두 방법간에 성능차이가 얼마나 나는지 궁금합니다
(물론 일반적으로는 RDBS 가 더 최적화 되어있을 것 같긴 하지만 실무에서 자바로 필터링하는 경우가 있는지도 궁금합니다)
좀 두서없이 쓴것 같은데 읽어주셔서 감사합니다ㅠ
답변 1
8
안녕하세요. Chung A님
결론은 데이터 양에 따라서 달라집니다. 데이터가 단순하고 수십 ~ 수백건 정도라면 성능에 크게 영향이 없을 수 있지만, 수천 ~ 수만건이라면 엄청난 성능 손실이 있습니다. 거의 서비스가 불가능하실 거에요.
일단 데이터를 DB -> 애플리케이션으로 다 퍼올려야 하는데, 네트워크 속도는 물론이고 자바 메모리도 매우 많이 사용합니다.
그래서 데이터가 정말 작은 경우가 아니면, 이런 방법은 사용하지 않는 것이 좋습니다.
결론은 DB에서 최대한 필터링하고 결과를 가져와야 합니다.
감사합니다.
0
안녕하세요 영한님, 오래된 질문글인데 지나가다가 최근에 고민하고 있던 문제라서 댓글 남깁니다!
DB에서 최대한 필터링하고 결과를 가져와야 하는 것에는 동의합니다!
다만, 실무에서 해당 필터링에 index 조건이 걸려있지 않은 컬럼에 대한 조건들이 존재해도 DB에서 최대한 필터링을 하는게 좋을까요? :)
그리고, fetchJoin을 사용하는 경우에 데이터양이 많아져 최적화가 필요할 때, oneToMany 에서 distinct를 사용하는 형태를 어떤식으로 튜닝해서 distinct를 걷어낼 수 있을까요?
읽어주셔서 감사합니다!
0
안녕하세요. hast_t님
일반적으로 DB에서 최대한 필터링 하는 것이 좋습니다. 그렇지 않으면 DB -> 애플리케이션 네트워크 전송 데이터가 너무 많아집니다. 물론 정답은 아니고 상황에 따라 다릅니다.
데이터 양이 많다면 fetch join이 아니라 DTO로 꼭 필요한 데이터를 조회하는 방법을 고민하는 것이 좋습니다.
감사합니다.
servlet과 container에 대한 질문입니다
0
25
1
api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?
0
64
1
jsp 의존성 수정 요청
0
80
2
요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?
0
143
1
save() 메서드 문의
0
67
1
절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상
0
101
1
request-body-json
0
83
2
MVC 패턴의 적용 단위
0
97
1
RequestMapping을 이용한 핸들러, 어댑터
0
119
2
save 후 결과화면
0
89
2
jsp를 이용한 view
0
97
1
application.properties에 debug 추가해도 결과가 똑같습니다.
0
178
1
수업 코드 제공 관련 문의
0
97
2
RequestMappingHandlerAdapter의 Controller 호출 과정
0
100
3
파일 오픈 시
0
70
1
스프링 배치 관련
0
78
1
@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부
0
112
1
postman으로 /request-body-json-v1 호출시 500 error
0
96
1
프론트엔드와 백엔드의 mvc, rest api에 대한 질문
0
79
1
모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문
0
111
1
console log 출력 관련 질문입니다.
0
75
1
애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ
0
139
1
html 변경하는 부분 적용 문제
0
103
1
한글 깨짐
0
77
2





