OPEN HYPER STEP
← 목록으로 (Supabase)
SUPABASE · 31 / 34
supabase
CHAPTER 31 / 34
읽기 약 2
FUNCTION

학습 진도 저장


핵심 개념

사용자 학습 진도를 Supabase에 저장하고 조회합니다. 챕터 완료, 마지막 위치를 추적합니다.

코드 분석
SUPABASE📋 코드 (21줄)
-- 진도 테이블
CREATE TABLE progress (
  user_id uuid REFERENCES auth.users,
  chapter_id int,
  completed boolean DEFAULT false,
  completed_at timestamptz,
  PRIMARY KEY (user_id, chapter_id)
);

// 챕터 완료 저장
await supabase.from('progress').upsert({
  user_id: userId,
  chapter_id: chapterId,
  completed: true,
  completed_at: new Date().toISOString()
}, { onConflict: 'user_id,chapter_id' })

// 완료 챕터 목록
const { data } = await
  supabase.from('progress').select('chapter_id')
    .eq('user_id', userId).eq('completed', true)

AI 프롬프트
🤖 AI에게 잘 물어보는 법 — 모델·전략별 프롬프트
Claude

무료: Sonnet 4.6 / Pro $20/mo: Opus 4.6

이 Supabase '학습 진도 저장' RLS 정책에서
보안 구멍·우회 가능한 케이스·과도한 권한을 찾고
안전한 정책 코드를 작성해줘.
ChatGPT

무료: GPT-5.5 / Plus $20/mo: GPT-5.5 Pro

'학습 진도 저장'를 Next.js + Supabase로 구현한
실전 풀스택 코드(Auth/RLS/Realtime 포함)를 만들어줘.
Gemini

무료: 2.5 Flash / Pro $19.99/mo: 3.1 Pro

이 Supabase '학습 진도 저장' 관련 테이블·RLS 정책 전체를 분석해서
보안 취약점·N+1 쿼리·인덱스 누락을
우선순위 리포트로 만들어줘.
Grok

무료: Grok 4.1 / SuperGrok $30/mo

Supabase '학습 진도 저장' vs Firebase의
동일 기능 구현을 2026년 기준
비용·성능·DX로 솔직히 비교해줘.

⭐ 이것만 기억하세요
학습 진도 저장 이 3가지만 확실히 잡으세요
1.학습 진도를 localStorage에만 저장하면 다른 기기에서 접속 시 진도가 초기화됩니다
2.user_progress 테이블에 사용자별 완료 챕터를 저장하고, RLS로 본인 데이터만 접근하게 하며, upsert로 중복을 방지합니다
3.다음 챕터에서 대시보드 통계를 구현합니다


공유하기
진행도 31 / 34