데이터베이스 (Database)
데이터를 체계적으로 저장하고, 필요할 때 빠르게 찾아 쓸 수 있도록 정리해주는 디지털 저장소입니다.
🤔 혹시 이런 경험 있나요?
AI에게 "회원가입 기능 만들어줘"라고 했더니 Supabase, Firebase, Neon 같은 서비스를 연결하라고 합니다. 또는 "데이터베이스 스키마를 설정하세요"라는 안내가 나옵니다. 대체 데이터베이스가 뭐고, 왜 앱을 만들 때마다 필요한 걸까요?
🗄️ 엑셀 스프레드시트의 진화판
가장 쉽게 이해하는 방법은 엑셀 스프레드시트를 떠올리는 것입니다.
엑셀에서 고객 명단을 관리한다고 생각해보세요. 이름, 이메일, 가입일을 열(Column)로 만들고, 한 명씩 행(Row)으로 추가합니다. 데이터베이스도 기본적으로 이와 같은 구조입니다. 다만 엑셀과 다른 점이 있습니다.
- 동시 접속: 수천 명이 동시에 읽고 쓸 수 있습니다.
- 속도: 수백만 건의 데이터에서도 원하는 정보를 빠르게 찾습니다.
- 안정성: 컴퓨터가 꺼져도 데이터가 사라지지 않습니다.
- 규칙 설정: "이메일은 반드시 입력해야 합니다" 같은 제약 조건을 걸 수 있습니다.
📊 SQL vs NoSQL: 두 가지 종류
데이터베이스는 크게 두 가지 종류가 있습니다.
SQL 데이터베이스 (관계형)
엑셀처럼 표(테이블) 형태로 데이터를 저장합니다. 데이터 간의 관계를 정의할 수 있어서 "관계형 데이터베이스"라고 부릅니다.
-- users 테이블
| id | name | email |
|----|--------|--------------------|
| 1 | 홍길동 | hong@example.com |
| 2 | 김철수 | kim@example.com |
-- posts 테이블 (user_id로 users와 연결)
| id | title | user_id |
|----|-------------|---------|
| 1 | 첫 번째 글 | 1 |
| 2 | 두 번째 글 | 1 |"홍길동이 쓴 글 목록"을 찾으려면 user_id = 1인 게시글을 조회하면 됩니다. 대표적인 서비스로 PostgreSQL, MySQL, Supabase, Neon 등이 있습니다.
NoSQL 데이터베이스 (비관계형)
표 대신 JSON과 비슷한 문서(Document) 형태로 데이터를 저장합니다. 구조가 자유로워서 유연하게 사용할 수 있습니다.
{
"name": "홍길동",
"email": "hong@example.com",
"posts": [
{ "title": "첫 번째 글" },
{ "title": "두 번째 글" }
]
}대표적인 서비스로 Firebase, MongoDB 등이 있습니다. 바이브코딩 프로젝트에서는 빠르게 프로토타입을 만들 때 NoSQL을 많이 사용합니다.
🧱 스키마: 데이터의 설계도
스키마(Schema)는 데이터가 어떤 구조로 저장될지 미리 정해놓은 설계도입니다. 집을 짓기 전에 도면을 그리는 것과 같습니다.
users 테이블 스키마:
- id: 숫자 (자동 생성, 고유값)
- name: 문자열 (필수)
- email: 문자열 (필수, 고유값)
- created_at: 날짜 (자동 생성)AI에게 "유저 테이블 만들어줘"라고 하면 이런 스키마를 자동으로 생성해줍니다. 스키마를 잘 설계하면 나중에 데이터가 꼬이는 문제를 예방할 수 있습니다.
🛠️ 바이브코딩에서 자주 만나는 DB 서비스
| 서비스 | 특징 | 적합한 경우 |
|---|---|---|
| Supabase | PostgreSQL 기반, 인증 기능 내장 | 풀스택 앱, 회원 관리 |
| Neon | PostgreSQL, 서버리스 | 가볍고 빠른 프로젝트 |
| Firebase | NoSQL, 실시간 동기화 | 채팅, 실시간 앱 |
| PlanetScale | MySQL 기반, 자동 확장 | 대규모 서비스 |
AI에게 프로젝트를 요청하면 보통 이 중 하나를 추천합니다. 초보자라면 Supabase가 가장 시작하기 쉽습니다. 대시보드에서 테이블을 직접 만들고, 데이터를 눈으로 확인할 수 있기 때문입니다.
⚠️ 바이브코딩할 때 흔한 DB 실수
1. 데이터베이스 연결 정보를 코드에 직접 넣는 실수
데이터베이스 URL, 비밀번호 같은 정보는 반드시 환경 변수(.env)에 저장해야 합니다. GitHub에 올리면 누구나 여러분의 데이터베이스에 접근할 수 있습니다.
2. 백업 없이 데이터를 삭제하는 실수
AI에게 "테이블 다시 만들어줘"라고 했다가 기존 데이터가 모두 사라질 수 있습니다. 변경 전에 항상 "기존 데이터는 유지하면서"라고 명시하세요.
3. 스키마 설계를 건너뛰는 실수
빨리 만들고 싶은 마음에 스키마 설계 없이 시작하면, 나중에 데이터 구조를 바꿔야 할 때 훨씬 복잡해집니다. AI에게 먼저 "이 앱에 필요한 데이터베이스 스키마를 설계해줘"라고 요청하는 것이 좋습니다.
📋 30초 요약
-
데이터베이스는 앱의 데이터를 저장하는 디지털 저장소입니다. 엑셀과 비슷하지만, 수천 명이 동시에 사용할 수 있고 훨씬 빠릅니다.
-
SQL(표 형태)과 NoSQL(문서 형태) 두 종류가 있으며, 바이브코딩에서는 Supabase, Firebase 같은 클라우드 서비스를 주로 사용합니다.
-
스키마(데이터 설계도)를 먼저 설계하고, 연결 정보는 환경 변수에 보관하세요. AI에게 요청할 때도 스키마 설계부터 시작하는 것이 좋습니다.
바이브코딩으로 회원가입 기능이 있는 웹 앱을 만들려고 합니다. AI가 Supabase를 추천했는데, Supabase에서 '사용자 정보를 어떤 구조로 저장할지 미리 정의한 것'을 무엇이라고 할까요?
연관 개념
터미널과 CLI (Terminal & CLI)
컴퓨터에게 텍스트 명령어를 입력해서 작업을 수행하는 도구입니다. AI 코딩 도구가 '이 명령어를 실행하세요'라고 할 때 사용하는 바로 그 검은 화면입니다.
환경 변수와 .env (Environment Variables)
프로그램이 실행될 때 참조하는 설정값으로, API 키나 비밀번호 같은 민감한 정보를 코드와 분리하여 안전하게 관리하는 방법입니다.
Git과 버전 관리 (Version Control)
파일의 변경 이력을 기록하고 관리하는 시스템입니다. AI가 코드를 대량으로 수정해도, 이전 상태로 되돌리거나 변경 내역을 추적할 수 있게 해줍니다.
관련 인사이트
바이브코딩 vs AI 에이전트 다른점 알아보기
바이브코딩과 AI 에이전트(Claude Code 등)를 모두 실무에 사용해 본 경험을 바탕으로, 둘의 작업 방식·코드 이해 수준·적합한 상황이 어떻게 다른지 비유와 비교표로 정리했습니다.
초보자를 위한 OAuth 2.0 이해하기
바이브코딩과 AI 에이전트로 빠르게 서비스를 만들 수 있는 시대입니다. 하지만 인증 구조를 이해하지 못하면 비밀번호가 코드에 그대로 노출되는 사고가 일어납니다. 인증의 기본 개념부터 OAuth 2.0까지, 비개발자도 이해할 수 있도록 정리했습니다.
Claude Code 커뮤니티에서 찾은 커스텀 Skill 세 가지 패턴
Claude Code의 핵심은 코드 생성이 아니라 Skill 시스템입니다. TDD 강제, 팀 맞춤 코드 리뷰, 실행 가능한 런북까지 — 전 세계 커뮤니티에서 실제로 쓰이는 3가지 커스텀 Skill 패턴을 정리했습니다.
