ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
基本的な使い方
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
}
5 つの戦略
| 戦略 | 動作 | パフォーマンス | 主な対応 DB |
|---|---|---|---|
IDENTITY | DB の AUTO_INCREMENT に依存 | 普通(バッチ非対応) | MySQL / PostgreSQL / SQL Server |
SEQUENCE | DB シーケンスを取得 | 高速(allocationSize で連続予約) | Oracle / PostgreSQL / DB2 / H2 |
TABLE | カウンタ用テーブルで管理 | 低速(DB ロック) | 全 DB |
AUTO | Hibernate が DB に応じて選択 | DB 依存 | 標準 |
UUID | UUID 自動生成(Hibernate 6+) | 高速 | 標準 |
IDENTITY
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
# MySQL: BIGINT AUTO_INCREMENT
# PostgreSQL: BIGSERIAL
# SQL Server: IDENTITY(1,1)
SEQUENCE(推奨:パフォーマンス)
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "user_seq")
@SequenceGenerator(
name = "user_seq",
sequenceName = "user_sequence",
allocationSize = 50,
initialValue = 1
)
private Long id;
# DDL
CREATE SEQUENCE user_sequence START WITH 1 INCREMENT BY 50;
# allocationSize: 一度に取得する ID の個数
# 例: 50 にすると 1 回の DB クエリで 50 個の ID を予約
# 50 行 INSERT を 1 回のシーケンス取得で済ませられる
TABLE(最後の手段)
@Id
@GeneratedValue(strategy = GenerationType.TABLE, generator = "user_tab_gen")
@TableGenerator(
name = "user_tab_gen",
table = "id_generator",
pkColumnName = "gen_name",
valueColumnName = "gen_value",
pkColumnValue = "user_id",
allocationSize = 50
)
private Long id;
# 内部的にカウンタテーブルを使う
# - SELECT で現在値取得
# - UPDATE で次の値に
# - DB ロックが発生してパフォーマンス悪い
# - すべての DB で動く利点はあるが、原則使わない
AUTO
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
# Hibernate のバージョンと DB に応じて選択
# Hibernate 4: 多くの場合 SEQUENCE
# Hibernate 5+: DB の AUTO_INCREMENT があれば IDENTITY、なければ SEQUENCE
# 明示しないと意図と違う動作になることがあるので、明示推奨
UUID(Hibernate 6+)
@Id
@GeneratedValue(strategy = GenerationType.UUID)
private UUID id;
# 自動で UUID v4 が生成される
# DB に依存しないため分散システムで衝突なし
# カラム型: VARCHAR(36) または BINARY(16)
# Hibernate 5 で UUID を使いたい場合
@Id
@GeneratedValue(generator = "uuid2")
@GenericGenerator(name = "uuid2", strategy = "org.hibernate.id.UUIDGenerator")
@Column(columnDefinition = "char(36)")
private String id;
パフォーマンス比較
IDENTITY の制限
バッチ INSERT で1 件ずつ ID を取得する必要があり、JdbcBatchSize が効きません:
// 1000 件 INSERT
for (int i = 0; i < 1000; i++) {
em.persist(new User("name" + i));
}
# IDENTITY: 1000 回の INSERT クエリ(バッチ不可)
# SEQUENCE: シーケンス取得 1000 / allocationSize 回 + INSERT バッチ 1000/jdbc.batch_size 回
大量 INSERT に最適化
# application.properties
spring.jpa.properties.hibernate.jdbc.batch_size=100
spring.jpa.properties.hibernate.order_inserts=true
spring.jpa.properties.hibernate.order_updates=true
# SEQUENCE で allocationSize を大きくする
@SequenceGenerator(name = "user_seq", sequenceName = "user_seq", allocationSize = 100)
カスタム ID 生成
// 独自のジェネレータを実装
public class UserIdGenerator implements IdentifierGenerator {
@Override
public Object generate(SharedSessionContractImplementor session, Object obj) {
// 例: USR-2026-001 形式
long count = (long) session.createQuery("SELECT COUNT(u) FROM User u").uniqueResult();
return String.format("USR-%d-%03d", LocalDate.now().getYear(), count + 1);
}
}
@Id
@GeneratedValue(generator = "user-id-gen")
@GenericGenerator(name = "user-id-gen", strategy = "com.example.UserIdGenerator")
private String id;
戦略選択のフローチャート
- 分散システム / 衝突回避が必要 → UUID
- Oracle / PostgreSQL で高速 INSERT → SEQUENCE
- MySQL でシンプルに使う → IDENTITY
- カスタムフォーマット ID → 自前ジェネレータ
- DB が変わる可能性 → AUTO(リスクあり)
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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アノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?