ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
SEQUENCE と AUTO_INCREMENT の違い
| 項目 | SEQUENCE | AUTO_INCREMENT / IDENTITY |
|---|---|---|
| 定義場所 | 独立した DB オブジェクト | カラムに付与 |
| 使い方 | SQL から明示的に取得 | INSERT で自動採番 |
| 共有 | 複数テーブルで共有可能 | そのテーブル専用 |
| 取得タイミング | INSERT 前 or トランザクション独立 | INSERT 後 |
| パフォーマンス | キャッシュで高速 (allocationSize) | 普通だがバッチが効きにくい |
| 主な対応 DB | Oracle / PostgreSQL / DB2 | MySQL / SQL Server / PostgreSQL |
SEQUENCE の使い方
Oracle
-- 作成
CREATE SEQUENCE user_seq
START WITH 1
INCREMENT BY 1
NOCACHE
NOCYCLE;
-- 取得
SELECT user_seq.NEXTVAL FROM DUAL; -- 次の値 (1, 2, 3, ...)
SELECT user_seq.CURRVAL FROM DUAL; -- 直前の値
-- INSERT で使用
INSERT INTO users (id, name) VALUES (user_seq.NEXTVAL, 'Alice');
-- バッチで高速化 (キャッシュ)
CREATE SEQUENCE user_seq START WITH 1 INCREMENT BY 1 CACHE 100;
PostgreSQL
-- 作成
CREATE SEQUENCE user_seq START WITH 1 INCREMENT BY 1;
-- 取得
SELECT nextval('user_seq'); -- 次の値
SELECT currval('user_seq'); -- 直前の値 (同セッション内)
-- INSERT
INSERT INTO users (id, name) VALUES (nextval('user_seq'), 'Alice');
-- SERIAL / BIGSERIAL (内部的に SEQUENCE 作成)
CREATE TABLE users (
id SERIAL PRIMARY KEY, -- INT + SEQUENCE 自動
name VARCHAR(100)
);
-- IDENTITY (PostgreSQL 10+, 標準 SQL 準拠)
CREATE TABLE users (
id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY,
name VARCHAR(100)
);
AUTO_INCREMENT / IDENTITY の使い方
MySQL
-- AUTO_INCREMENT
CREATE TABLE users (
id BIGINT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100)
);
-- INSERT (id 省略可)
INSERT INTO users (name) VALUES ('Alice'); -- id 自動採番
-- 採番された ID 取得
SELECT LAST_INSERT_ID();
-- AUTO_INCREMENT 開始値変更
ALTER TABLE users AUTO_INCREMENT = 1000;
SQL Server
-- IDENTITY
CREATE TABLE users (
id BIGINT IDENTITY(1, 1) PRIMARY KEY, -- 開始 1, 増分 1
name VARCHAR(100)
);
-- INSERT
INSERT INTO users (name) VALUES ('Alice');
-- 採番された ID 取得
SELECT SCOPE_IDENTITY();
SELECT @@IDENTITY;
-- 明示的に ID 指定したい場合
SET IDENTITY_INSERT users ON;
INSERT INTO users (id, name) VALUES (100, 'Special');
SET IDENTITY_INSERT users OFF;
PostgreSQL の SERIAL vs IDENTITY
-- SERIAL (古い書き方、互換性のため残存)
CREATE TABLE users (
id SERIAL PRIMARY KEY,
name VARCHAR(100)
);
-- 内部的に "users_id_seq" SEQUENCE が自動作成される
-- IDENTITY (推奨、SQL 標準準拠)
CREATE TABLE users (
id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY,
name VARCHAR(100)
);
-- 違い:
-- - GENERATED ALWAYS: 明示的に id 指定不可
-- - GENERATED BY DEFAULT: 必要なら指定可
JPA での選択
// IDENTITY (MySQL / SQL Server)
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
// SEQUENCE (Oracle / PostgreSQL)
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "user_seq")
@SequenceGenerator(name = "user_seq", sequenceName = "user_sequence", allocationSize = 50)
private Long id;
// AUTO (Hibernate が選択)
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
// UUID (Hibernate 6+)
@Id
@GeneratedValue(strategy = GenerationType.UUID)
private UUID id;
パフォーマンス比較
IDENTITY の制約
// IDENTITY だとバッチ INSERT で各行 1 つずつ ID 取得
// → JDBC バッチが効かない、遅い
// 1000 件 INSERT
for (int i = 0; i < 1000; i++) {
em.persist(new User("user" + i));
}
// IDENTITY: 1000 個別 INSERT (遅い)
// SEQUENCE + allocationSize=100: 10 回シーケンス + 1000 バッチ (10x 高速)
SEQUENCE の allocationSize
@SequenceGenerator(
name = "user_seq",
sequenceName = "user_sequence",
allocationSize = 100 // 100 件まとめて予約
)
# 動作:
# - シーケンス取得時、Hibernate が 1 回で 100 個 ID を確保
# - JVM メモリ内で 100 個使い切るまで DB アクセスなし
# - 大量 INSERT が大幅高速化
# 注意: 再起動・複数 JVM で ID 抜けが発生
# (許容できれば問題なし、シーケンスの目的は一意性であり連続性ではない)
UUID と比較
| 方式 | 長所 | 短所 |
|---|---|---|
| AUTO_INCREMENT / IDENTITY | シンプル・単一 DB で確実 | バッチ INSERT 遅い、分散システム不可 |
| SEQUENCE | バッチ最適化可、複数テーブル共有可 | DB 依存 |
| UUID | 分散システム OK、ID 採番に DB 不要 | 長い (36 chars)、ソート効率低 |
| Snowflake ID | 分散 + 時系列順 | 独自実装が必要 |
主キーの選定指針
- 単一 DB の中小規模システム: AUTO_INCREMENT / IDENTITY が単純
- Oracle / PostgreSQL でバッチ多用: SEQUENCE + allocationSize
- 分散システム / マイクロサービス: UUID
- 時系列ソートが重要 + 分散: Snowflake / ULID
- レガシー互換: 既存システムに合わせる
シーケンスのリセット・確認
-- Oracle
SELECT user_seq.NEXTVAL FROM DUAL; -- 現在値+1 を取得
-- リセットは drop + create (alter で nextval 直接設定不可)
DROP SEQUENCE user_seq;
CREATE SEQUENCE user_seq START WITH 1000;
-- PostgreSQL
SELECT currval('users_id_seq');
SELECT setval('users_id_seq', 1000); -- 次回 1001 から
SELECT setval('users_id_seq', 1000, false); -- 次回 1000 から
-- MySQL AUTO_INCREMENT
ALTER TABLE users AUTO_INCREMENT = 1000;
SHOW TABLE STATUS LIKE 'users'; -- 現在値確認
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?