검색 기능 만들기

2024년 6월 11일 화요일

Today I Learned

날짜

2024년 6월 11일 화요일

내용

검색 쿼리

유저가 여러 댓글 중 무언가를 검색하거나, 데이터를 정렬하는 기능을 만들어야 했다. 기존 프로덕트 리뷰에 있는 건 너어어어무 복잡하고, 온갖 기능이 추가되어 유지보수가 힘들었다. 아예 다른 곳에서 쓰이는 것일 뿐더러 기능이나 검색 단위, 정렬 단위도 더 작은 범위라 최대한 깔끔하게 만들려고 했다.

정렬 방식이 조금 난해했는데, 정렬 기준이 2개인 경우가 있었기 떄문이다. 이번 인스타그램 댓글 가져오는 앱의 테이블 구조는 샵 → 페이스북 페이지 → 게시글 → 댓글 순서로 이루어졌으며 각각 일대다관계다. 댓글의 작성일자로 정렬할 때는 별 어려움이 없으나, 게시글 작성일자로 정렬할 떄는 꽤 어려웠다. 최근에 작성된 게시글 내의 댓글들을 먼저 가져오되, 같은 게시글 내에선 최근에 작성된 댓글이 먼저와야 했다.

고민이 무색할정도로 쉽게 해결되었는데, order_by 에 넣는 순서로 해결되버렸다.. 페이지네이션을 위해 전체 데이터 갯수를 조회해야 했는데 하나의 쿼리로 처리할 수 없었다. 그냥 별개의 쿼리를 작성해서 데이터베이스에 2번 접근(데이터 조회를 위해 한번, 데이터 갯수를 세기 위해 한번)

회고

사랑니 에반데.