inflearn logo
강의

講義

知識共有

一口リアクト実践ライブラリキット - Zustand, Tanstack Query, TailwindCSS

(5.13) キャッシュを正規化する 2

(5.12) 캐시 정규화 하기 1 질문

48

kimsuro

投稿した質問数 4

0

안녕하세요
5.12 캐시 정규화하기 부분에 궁금한 부분이 있어 질문 남겨봅니다!

이 캐시 정규화는 리스트 페이지와 상세 페이지의 데이터가 같을 경우에만 사용 가능한 패턴인가요?

만약 상세 페이지에서 백엔드가 내려주는 데이터가 리스트 페이지와 비슷하지만 몇 개의 필드가 다르게 내려온다면 사용할 수 없는 패턴인가요?

react react-query

回答 2

0

winterlood

안녕하세요 김수로님 이정환입니다.

네 말씀하신대로 리스트 페이지에서의 데이터와 상세 페이지에서의 데이터가 구조가 다르다면 강의에서 소개해 드린 방식대로 정규화 하는 것은 다소 효율적이지는 않을 것 같습니다.

일단 정규화 한 뒤 상세 페이지에서 추가로 몇개의 필드를 불러왔을때 수동으로 저장된 캐시에 추가해주는 방법도 가능은 하나, 이러면 오히려 캐시 관리가 너무 복잡해져 다른 이슈가 발생할 수 있습니다. ㅠㅠ

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 김수로님.

캐시 정규화는 주로 데이터가 일관되게 여러 페이지 또는 컴포넌트에 나타날 때 유용합니다. 특히, 리스트 페이지와 상세 페이지에서 동일한 데이터 구조를 공유하고 있을 때 생산적인 패턴입니다.

캐시 정규화 사용 조건

  1. 데이터 구조의 일관성: 캐시 정규화는 데이터를 키를 기준으로 관리하며, 이를 통해 리스트 페이지와 상세 페이지 등 여러 컴포넌트가 동일한 데이터를 사용할 수 있도록 해줍니다.
  2. 데이터의 부분적 공유: 만약 상세 페이지의 데이터가 리스트 페이지의 데이터와 부분적으로 다르다면, 기본적인 캐시 정규화를 수정하여 적용할 수 있습니다. 즉, 공통된 필드를 기준으로 캐시를 구성하고, 상세 페이지에서만 필요한 데이터는 추가적으로 관리하는 방식으로 종합할 수 있습니다.

유사한 사례 연구

캐시 정규화에 대한 유용한 설명을 참고하려면 아래 링크들을 살펴보세요:

  • 캐시 정규화 기초와 적용: 이 설명은 리스트 페이지와 같은 컴포넌트에서 데이터 일관성을 유지하는 방법을 다룹니다.
  • Zustand와 캐시 관리: 실제 사용 경험을 공유한 사례로, 다양한 데이터 상태 관리에서 캐시 정규화를 어떻게 적용할 수 있는지를 설명합니다.

이러한 관리 방식은 설계와 사업 요구에 맞춰 커스터마이징하여 활용하실 수 있습니다. 마찬가지로, Tanstack Query와 같은 상태 관리 라이브러리에서의 캐시 정규화 기능을 적극 활용하시면, 더욱 효율적인 성능 최적화를 이루실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

<div id="banner">배너 이미지</div> 관련 질문

0

7

1

fatal: repository 'https://github.com/gymcoding/my-marketplace.git/' not found

0

15

2

live server, korean 을 검색해도 아무것도 나오지 않음

0

15

1

커서질문

0

19

1

강의자료

0

18

1

SUPABASE에서 AOI 선택여부

0

16

2

클로드 코드 터미널 사용시 git, git 허브 활용 법

0

22

1

mcp.json파일 생성 X

0

19

2

강의 내용이 정신이없네요 ;;

0

43

2

제 컴퓨터에서는 Claude's plan이 아래와 같이 나오는데 괜찮은 건가요?

0

27

2

강의에서 사용하는 prompt

0

22

2

window 11 환경 + git bash 터미널 statusline 반영이 안됩니다 ㅠ

0

27

2

강사님 질문있습니다.

0

20

1

프로젝트를 커밋할때 알려주세요

0

25

1

작업결과물이 수업내용의 화면이 좀 다르네요

0

34

2

강의 도중 에러가 발생합니다.

0

34

2

사진과 같이 영상에 한글이 실시간으로 영어로 번역되어 보입니다

0

35

2

커밋버튼 비활성화

0

32

2

Cursor 질문

0

24

2

웹사이트 구축 질문

0

37

1

플러그인, git repo 설치 및 삭제

0

31

1

쿠폰 문의 드립니다.

0

39

2

섹션3 Shadcn/ui 생성 시

0

142

1

섹션2 tailwindcss 퀴즈에 대해서

0

76

2