개발자

앱(Flutter)에서 JSON데이터를 검색하려고 합니다

2024년 04월 11일조회 111

안녕하세요 Flutter를 이용하여 식단 및 체성분 관리 앱을 개발 중인 대학생입니다! json형식의 식품영양성분 공공데이터 안에서 사용자가 입력한 식품명 검색어를 기준으로 데이터를 불러오려고 합니다. DB는 Google Firebase를 사용 중이며, 위와 같은 목적으로 데이터를 사용 할 때에 적합하지 않다면 다른 DB를 사용 할 의향도 있습니다. 사용자의 검색어로 시작하는 특정 데이터만이 아니라, 검색어를 "포함"하는 데이터도 불러오고 싶습니다. 현재 어느 정도 그려 본 방법입니다. 영양성분 JSON 다운로드 ↓ Python을 이용하여 필요한 데이터만 가공 ↓ Firebase Realtime Database / Storage에 저장 ↓ 저장된 JSON을 API 호출을 통해 String으로 불러옴 / 앱 내부에 .json 파일로 저장 ↓ Map으로 변환 후 캐싱 ↓ 사용자가 검색어 입력 ↓ 검색어를 포함하는 데이터만 별도 리스트에 추가 여기서 데이터를 불러오는 과정에서 필터링을 거치지 않는 이유는 Firebase Realtime Database에서는 검색어를 "포함"하는 것이 아닌, 사전 순으로 검색어 기준 뒤에 있는 데이터만 가능하다고 합니다.. 그래서 결국 JSON파일로 직접 사용하기로 했습니다 혹시나 저의 부족함이 보이시는 분들의 조언과 피드백을 듣고 싶습니다! 더 나은 방법이 있다면 무차별 폭격 및 질문 부탁드립니다! 미리 감사드립니다 (_ _)

이 질문이 도움이 되었나요?
'추천해요' 버튼을 누르면 좋은 질문이 더 많은 사람에게 노출될 수 있어요. '보충이 필요해요' 버튼을 누르면 질문자에게 질문 내용 보충을 요청하는 알림이 가요.
profile picture
익명님의 질문

답변 1

Jake님의 프로필 사진

안녕하세요! 저도 항상 어렵게 느끼는 부분인데, 제가 설계한 내용을 다른 사람에게 설명하는게 참 쉽지 않아요. 내가 수도없이 고민하고 생각해서 알고있는 내용을 자연스럽게 남들도 알거라고 생각하게 되거든요. 작성해주신 설계는 백엔드 서버의 처리와 앱에서 처리하는 내용이 뒤섞여있어서 바로 이해가기가 조금 어려웠어요! 결국 하시고자 하는것은, 1. 백엔드 서버에는 Static 영양 정보 데이터가 존재 2. App은 API를 통해 해당 데이터를 요청, 동기화 (JSON으로 저장 후 캐싱) 가 맞을까요? 그렇다면 플로우 자체에는 큰 문제가 없어 보입니다. 한가지 여쭤보고 싶은 것은, JSON파일로 저장하려는 이유는 무엇인가요? 이것도 큰 문제는 없지만 굳이 할 이유도 없어보여서요!

profile picture

익명

작성자

2024년 04월 11일

역시 제가 생각했던 부분을 바로 글로 쏟아내었더니 전달력이 부족했나봅니다ㅠㅜ - JSON 형태의 데이터를 사용하려는 이유 식품영양성분 공공데이터를 사용하기 위해서 OPEN API를 이용할 경우, 주소에서 식품 검색어를 "포함"하는 데이터가 아닌 "정확히 일치"하는 데이터만 필터가 가능하다는 것을 확인했습니다. 따라서 JSON형태의 파일을 별도 DB에 저장하여, 직접 검색 로직을 짜는 방법을 보고 있었습니다. - 하고자 하는 것 말씀하신 방향이 맞습니다! 2가지 방법을 생각해보고 있습니다. 1. DB에 저장된 JSON을 클라이언트에서 API로 호출하여 "모든" 영양소 데이터를 변환 및 캐싱 후 사용 2. DB에서 "JSON 파일" 자체를 클라이언트로 다운로드(프리로딩)하여 데이터 변환 및 캐싱 후 사용 데이터를 다뤄본 적이 없고, 이와 같은 고민을 해결하기 위해 삽질하다가 캐싱의 중요성도 이제야 알게 되면서 점점 효율적인 방법이 무엇인지 파고드는 중입니다. + + [ 제가 설계한 내용을 다른 사람에게 설명하는게 참 쉽지 않아요. 내가 수도없이 고민하고 생각해서 알고있는 내용을 자연스럽게 남들도 알거라고 생각하게 되거든요. ] 서두의 말씀이 뭔가 한대 맞은 느낌이네요... 질문이냐 응답이냐에 상관 없이 제가 전달하고픈 내용을 최대한 효율적으로 전달하려 노력하겠습니다 정말 감사합니다!

지금 가입하면 모든 질문의 답변을 볼 수 있어요!

현직자들의 명쾌한 답변을 얻을 수 있어요.

또는

이미 회원이신가요?

AI 답변
커리어리 AI 봇 프로필 이미지

커리어리 AI 봇

GPT가 달아주는 답변입니다.

2024년 04월 11일

안녕하세요, Flutter와 Firebase를 사용하여 앱을 개발하고 있는 것이 인상적입니다. 플랫폼에 간단한 데이터베이스 검색 기능을 추가하려는 의도가 이해됩니다. 위에서 제시한 방법은 올바르지만, 음식 이름을 가져오는 것이 주된 목표라면, 데이터베이스 솔루션을 조금더 고려해 볼 만합니다. Firebase Firestore는 여러분의 요구사항에 맞게 설계된 더 좋은 대안일 수 있습니다. Firestore의 Collection과 Document 구조를 사용해 텍스트 검색을 최적화할 수 있습니다. - `food_document`: 각각의 식품 항목(document)을 나타내며 필드 값으로 식품 이름(name), 영양소 정보(nutrition_info) 등 다른 메타데이터들을 가질 수 있습니다. Firestore에서는 .where 메소드를 사용하여 부분 문자열로 문서를 쿼리할 수 있으므로, 사용자가 입력한 단어나 구절을 포함하는 모든 식품 항목을 아래와 같이 찾아올 수 있습니다: ```dart var query = firestore.collection('food_documents').where('name', arrayContains: user_input); ``` Firestore가 비교적 새로운 시스템인 만큼, 검색 쿼리 지원에 아직 한계가 있습니다. 그렇기에 Algolia와 같은 서드파티 검색 서비스를 사용하여 Firestore 데이터베이스에 대한 Full Text Search 기능을 추가하는 방법도 고려해 볼 수 있습니다. 정리하면, 당신의 현재 접근방식이 잘못되었다는 것은 아니지만, 몇 가지 다른 옵션들을 살펴보고 제안하였습니다. 기능 요구사항에 따라 적합한 선택을 하시길 바랍니다.

목록으로

지금 가입하면 모든 질문의 답변을 볼 수 있어요!