supabase
CHAPTER 16 / 34
읽기 약 2분
SYNTAX
뷰 & 구체화된 뷰
핵심 개념
PostgreSQL 뷰로 복잡한 쿼리를 단순화합니다. 구체화된 뷰로 집계 데이터를 캐싱합니다.
코드 분석
-- 일반 뷰
CREATE VIEW posts_with_author AS
SELECT p.*, pr.username, pr.avatar_url
FROM posts p
JOIN profiles pr ON p.user_id = pr.id;
-- 구체화된 뷰 (대시보드용)
CREATE MATERIALIZED VIEW daily_stats AS
SELECT
DATE(created_at) AS date,
COUNT(*) AS post_count
FROM posts
GROUP BY DATE(created_at);
-- 새로고침
REFRESH MATERIALIZED VIEW daily_stats;
// 뷰 사용
const { data } = await
supabase.from('posts_with_author').select('*')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.같은 JOIN + 필터 조합을 여러 곳에서 반복하면 변경 시 모든 곳을 수정해야 합니다
2.VIEW로 복잡한 쿼리를 저장하고, MATERIALIZED VIEW로 결과를 캐싱하면 성능과 유지보수를 동시에 개선합니다
3.다음 챕터에서 텍스트 검색을 위한 pg_trgm을 배웁니다
공유하기
진행도 16 / 34