Agent skill
query-engine-design
SQL query engine design and implementation guide. Use when the user requests building a SQL engine, query parser, query planner, or query executor — including in-memory storage, SQL parsing, and query optimization.
Install this agent skill to your Project
npx add-skill https://github.com/revfactory/claude-code-harness/tree/main/experiments/results/case-009/harness/.claude/skills/query-engine-design
SKILL.md
Query Engine Design Skill
SQL 쿼리 엔진 설계 및 구현 가이드
3단계 파이프라인 워크플로우
SQL 문자열 → [Parser] → AST → [Planner] → 실행계획 → [Executor] → 결과셋
↑
[StorageEngine]
- Parser: SQL 문자열을 AST로 변환 (재귀 하강)
- Planner: 논리적 실행 계획 → 물리적 실행 계획
- Executor: 실행 계획을 순회하며 결과셋 생성
SQL 지원 범위 (우선순위)
- CREATE TABLE, DROP TABLE, INSERT INTO
- SELECT (*, columns, aliases)
- WHERE (비교, AND/OR, LIKE, IN, BETWEEN, IS NULL)
- ORDER BY, LIMIT/OFFSET
- 집계 (COUNT, AVG, SUM, MIN, MAX)
- GROUP BY + HAVING
- JOIN (INNER, LEFT)
- 서브쿼리 (WHERE IN subquery)
- UPDATE, DELETE
- DISTINCT
NULL 3값 로직 규칙
NULL = NULL→ NULL (not true)NULL AND true→ NULLNULL OR true→ trueIS NULL/IS NOT NULL로만 NULL 비교
파일 구조
src/
lexer.js - SQL 토크나이저
parser.js - 재귀 하강 SQL 파서
ast.js - SQL AST 노드 정의
planner.js - 논리적 → 물리적 쿼리 계획
executor.js - 쿼리 실행기
storage.js - 인메모리 테이블 저장소 + 스키마
expression.js - WHERE 절 / 산술식 평가기
aggregator.js - 집계 함수 (COUNT, AVG, SUM, MIN, MAX)
formatter.js - 결과 테이블 포맷터
repl.js - 대화형 SQL 실행
index.js - CLI 진입점
tests/
parser.test.js
executor.test.js
integration.test.js
핵심 규칙
- 파서-플래너-실행기 완전 분리
- 대소문자 무시 (키워드)
- 스키마 타입: INT, FLOAT, TEXT
테스트 전략
- Parser: 각 SQL 문법별 AST 생성 확인
- Executor: 단순 SELECT → WHERE → ORDER BY → 집계 → GROUP BY → JOIN → 서브쿼리 순서
- Integration: 검증 쿼리 2개 (부서별 통계 + JOIN 서브쿼리)
- Edge Cases: NULL 처리, 빈 테이블, 존재하지 않는 컬럼
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
interpreter-design
Programming language interpreter design and implementation guide. Use when the user requests building an interpreter, parser, lexer, or language implementation — including Pratt parsing, AST evaluation, scope chains, and closures.
express-api-design
Express.js REST API design and implementation guide. Use when implementing REST API endpoints, creating Express routes, or setting up API project structure with MVC pattern.
api-documentation
Write accurate and complete library API documentation. Use when creating API docs, README files, or function reference documentation. Ensures all signatures, parameters, return types, and examples are precise.
async-debugging
Analyze and fix race conditions and concurrency bugs in async code. Use when debugging async bugs, fixing race conditions, resolving concurrency issues, or when shared state is accessed by multiple async operations.
reactive-spreadsheet-design
리액티브 스프레드시트 엔진 설계 가이드. 셀 수식 파싱, 의존성 그래프(DAG), 증분 재계산, 내장 함수 구현 시 사용한다.
lsp-design
Language Server Protocol 서버 구현 가이드. LSP 서버, 증분 파싱, 자동완성, 진단, Go-to-Definition, 호버를 구현할 때 사용한다.
Didn't find tool you were looking for?