メインコンテンツにスキップ

SQL Formatter

SQLクエリを読みやすくフォーマットし、圧縮するツールです。複雑なクエリを整理し、チーム内のSQLコーディングスタイルを統一しましょう!

Examples:
Formatted SQL will appear here...

💡 Tips

  • 복잡한 쿼리를 읽기 쉽게 포맷팅하세요
  • 팀 내 SQL 코딩 스타일을 통일하세요
  • Compress 기능으로 쿼리를 한 줄로 만들 수 있습니다
  • 여러 SQL 문을 한 번에 포맷팅할 수 있습니다

主要機能

1. SQLフォーマット

  • キーワード、カラム、テーブル名を適切にインデント
  • 可読性向上のための改行
  • 一貫したコーディングスタイルの適用

2. 多様なSQL方言のサポート

  • Standard SQL
  • MySQL
  • PostgreSQL
  • MariaDB
  • PL/SQL (Oracle)
  • T-SQL (SQL Server)
  • SQLite

3. カスタマイズオプション

  • インデントスタイル(2スペース、4スペース、タブ)
  • キーワードの大文字化
  • クエリ間の行間隔調整

4. 圧縮機能

  • 不要な空白の削除
  • 1行に圧縮

使用例

フォーマット前

SELECT u.id,u.name,u.email,o.order_id,o.total FROM users u LEFT JOIN orders o ON u.id=o.user_id WHERE u.active=1 AND o.total>100 ORDER BY o.total DESC LIMIT 10;

フォーマット後

SELECT
u.id,
u.name,
u.email,
o.order_id,
o.total
FROM
users u
LEFT JOIN orders o ON u.id = o.user_id
WHERE
u.active = 1
AND o.total > 100
ORDER BY
o.total DESC
LIMIT
10;

ユースケース

1. コードレビュー

-- 複雑なクエリをフォーマットしてレビューしやすく
WITH monthly_sales AS (
SELECT
DATE_TRUNC('month', order_date) AS month,
SUM(total) AS revenue
FROM
orders
GROUP BY
DATE_TRUNC('month', order_date)
)
SELECT
month,
revenue,
LAG(revenue) OVER (
ORDER BY
month
) AS prev_month_revenue
FROM
monthly_sales;

2. ドキュメント化

-- READMEやドキュメントに含めるSQLをきれいに整理
CREATE TABLE users (
id SERIAL PRIMARY KEY,
name VARCHAR(100) NOT NULL,
email VARCHAR(255) UNIQUE NOT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX idx_users_email ON users (email);

3. デバッグ

-- ログからコピーした1行クエリを読みやすく
SELECT
p.id,
p.name,
c.name AS category,
COUNT(o.id) AS order_count
FROM
products p
INNER JOIN categories c ON p.category_id = c.id
LEFT JOIN order_items o ON p.id = o.product_id
WHERE
p.active = TRUE
GROUP BY
p.id,
p.name,
c.name
HAVING
COUNT(o.id) > 10;

4. 複雑なCTE(Common Table Expression)

WITH RECURSIVE subordinates AS (
SELECT
employee_id,
manager_id,
full_name,
1 AS level
FROM
employees
WHERE
manager_id IS NULL
UNION ALL
SELECT
e.employee_id,
e.manager_id,
e.full_name,
s.level + 1
FROM
employees e
INNER JOIN subordinates s ON s.employee_id = e.manager_id
)
SELECT
employee_id,
full_name,
level
FROM
subordinates
ORDER BY
level,
full_name;

圧縮機能の活用

いつ使用するか?

  1. ログ分析: 複数行のクエリを1行にしてgrep検索
  2. URLパラメータ: クエリをURLに含める場合
  3. スペース節約: コードで簡単なクエリをインラインで使用

-- 圧縮前(複数行)
SELECT
id,
name
FROM
users
WHERE
active = TRUE;

-- 圧縮後(1行)
SELECT id,name FROM users WHERE active=TRUE;

ベストプラクティス

1. 一貫したスタイル

チーム内で同じフォーマット設定を使用:

  • インデント: 2スペース
  • キーワード: 大文字
  • 行間隔: 1

2. 複雑なクエリはCTEを使用

-- Good: CTEで分離
WITH active_users AS (
SELECT * FROM users WHERE active = TRUE
),
recent_orders AS (
SELECT * FROM orders WHERE created_at > NOW() - INTERVAL '30 days'
)
SELECT
u.*,
COUNT(o.id) AS order_count
FROM
active_users u
LEFT JOIN recent_orders o ON u.id = o.user_id
GROUP BY
u.id;

3. サブクエリの代わりにJOIN

-- Bad: サブクエリ
SELECT
*
FROM
orders
WHERE
user_id IN (
SELECT
id
FROM
users
WHERE
active = TRUE
);

-- Good: JOINを使用
SELECT
o.*
FROM
orders o
INNER JOIN users u ON o.user_id = u.id
WHERE
u.active = TRUE;

4. 明示的なカラムの列挙

-- Bad: SELECT *
SELECT * FROM users;

-- Good: 明示的なカラム
SELECT
id,
name,
email,
created_at
FROM
users;

サポートされているSQL構文

DDL(Data Definition Language)

CREATE TABLE, ALTER TABLE, DROP TABLE
CREATE INDEX, DROP INDEX
CREATE VIEW, DROP VIEW

DML(Data Manipulation Language)

SELECT, INSERT, UPDATE, DELETE
MERGE(一部の方言)

高度な機能

-- CTE(Common Table Expression)
WITH cte_name AS (...)

-- ウィンドウ関数
ROW_NUMBER(), RANK(), LAG(), LEAD()

-- 結合
INNER JOIN, LEFT JOIN, RIGHT JOIN, FULL JOIN, CROSS JOIN

-- サブクエリ
WHERE id IN (SELECT ...), FROM (SELECT ...) AS subquery

ヒントとコツ

1. 長いクエリは段階的に作成

-- ステップ1: 基本SELECT
SELECT * FROM users;

-- ステップ2: JOIN追加
SELECT * FROM users u
JOIN orders o ON u.id = o.user_id;

-- ステップ3: WHERE条件
SELECT * FROM users u
JOIN orders o ON u.id = o.user_id
WHERE u.active = TRUE;

-- ステップ4: フォーマット

2. コメントの活用

-- ユーザー別注文統計の取得
SELECT
u.id,
u.name,
COUNT(o.id) AS total_orders, -- 総注文数
SUM(o.total) AS total_revenue -- 総売上
FROM
users u
LEFT JOIN orders o ON u.id = o.user_id
GROUP BY
u.id,
u.name;

3. テーブルエイリアスの一貫性

-- 最初の文字を使用
FROM users u, orders o

-- 意味のある略語
FROM users usr, orders ord

注意事項

  • フォーマッタはSQL構文を検証しません
  • 方言によって若干の違いがある場合があります
  • 圧縮機能は可読性を犠牲にします(必要な場合にのみ使用)
  • コメントはフォーマット時に保持されます

関連ツール

キーボードショートカット

多くのSQLエディタがフォーマットのショートカットを提供しています:

  • VS Code: Shift + Alt + F
  • JetBrains: Ctrl + Alt + L
  • DBeaver: Ctrl + Shift + F