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

데이터베이스 함수


핵심 개념

PostgreSQL 함수로 복잡한 비즈니스 로직을 DB에 캡슐화합니다. supabase.rpc()로 호출합니다.

코드 분석
SUPABASE📋 코드 (20줄)
-- 조회수 증가 함수
CREATE OR REPLACE FUNCTION increment_views(post_id uuid)
RETURNS void LANGUAGE sql AS $$
  UPDATE posts
  SET views = views + 1
  WHERE id = post_id;
$$;

-- 사용자 통계 함수
CREATE OR REPLACE FUNCTION get_user_stats(uid uuid)
RETURNS TABLE(post_count int, total_views int)
LANGUAGE plpgsql AS $$
BEGIN
  RETURN QUERY SELECT
    COUNT(*)::int, COALESCE(SUM(views), 0)::int
  FROM posts WHERE user_id = uid;
END$$;

// JS에서 호출
await supabase.rpc('increment_views', { post_id: id })

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.복잡한 계산을 클라이언트에서 여러 쿼리로 처리하면 네트워크 비용이 크고 트랜잭션 보장이 안 됩니다
2.PostgreSQL 함수(CREATE FUNCTION)로 DB 내부에서 로직을 실행하고, supabase.rpc('함수명')으로 호출합니다
3.다음 챕터에서 복잡한 쿼리를 저장하는 뷰를 배웁니다


공유하기
진행도 15 / 34