ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
@Id の基本
@Entity
@Table(name = "users")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(nullable = false)
private String name;
}
@Id は必須です。なければ起動時に No identifier specified for entity エラー。
主キー生成戦略 (@GeneratedValue)
| 戦略 | 動作 | 主な DB |
|---|---|---|
IDENTITY | DB の AUTO_INCREMENT に任せる | MySQL / PostgreSQL / SQL Server |
SEQUENCE | DB シーケンスから取得 | Oracle / PostgreSQL / DB2 |
TABLE | カウンタテーブルから取得 | すべての DB(パフォーマンス低) |
AUTO | JPA プロバイダが選択 | DB 依存 |
UUID | UUID 自動生成(Hibernate 6+) | 標準 |
IDENTITY(MySQL / PostgreSQL 標準)
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
# 生成される DDL
# MySQL
CREATE TABLE users (
id BIGINT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id)
);
# PostgreSQL
CREATE TABLE users (
id BIGSERIAL NOT NULL PRIMARY KEY,
...
);
SEQUENCE(Oracle / PostgreSQL 推奨)
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "user_seq")
@SequenceGenerator(name = "user_seq", sequenceName = "user_sequence", allocationSize = 50)
private Long id;
# allocationSize: 一度に取得する ID の個数 (50 だと 50 個まとめて取って、JVM 内で順次使う)
# → DB アクセスが減り、バッチ INSERT が速くなる
# 生成される DDL
CREATE SEQUENCE user_sequence INCREMENT BY 50;
UUID(Hibernate 6+ / 分散システム向け)
@Id
@GeneratedValue(strategy = GenerationType.UUID)
@Column(columnDefinition = "VARCHAR(36)") // または BINARY(16)
private UUID id;
# 自動で UUID が割り当てられる
# 利点: DB に依存せず生成可能、分散システムで衝突しない
# 欠点: 長い (36 文字)、ソート効率が悪い
アプリ側で生成(@GeneratedValue なし)
@Id
private String code; // 例: "USR-2026-001" を自分でセット
User user = new User();
user.setCode("USR-2026-001");
userRepository.save(user);
複合キー(Composite Primary Key)
方法 1: @IdClass
// 別のクラスで主キーを表現
public class OrderItemId implements Serializable {
private Long orderId;
private Long productId;
public OrderItemId() {}
public OrderItemId(Long o, Long p) { orderId = o; productId = p; }
@Override public boolean equals(Object o) { ... }
@Override public int hashCode() { ... }
}
@Entity
@IdClass(OrderItemId.class)
public class OrderItem {
@Id private Long orderId;
@Id private Long productId;
private int quantity;
}
// 検索
OrderItem item = em.find(OrderItem.class, new OrderItemId(1L, 2L));
方法 2: @EmbeddedId(推奨)
@Embeddable
public class OrderItemId implements Serializable {
@Column(name = "order_id") private Long orderId;
@Column(name = "product_id") private Long productId;
// equals/hashCode + コンストラクタ
}
@Entity
public class OrderItem {
@EmbeddedId
private OrderItemId id;
private int quantity;
}
// 検索
OrderItem item = em.find(OrderItem.class, new OrderItemId(1L, 2L));
関連エンティティの主キー(@MapsId)
// User と UserProfile が 1 対 1、主キーを共有
@Entity
public class UserProfile {
@Id
private Long id; // user_id と同じ値
@MapsId // id を user.id にマップ
@OneToOne
@JoinColumn(name = "id")
private User user;
}
主キーの型選択
| 型 | 用途 | 備考 |
|---|---|---|
Long | 標準的な自動採番 | 連番、ソート効率良い、最大 9 京 |
Integer | 小規模システム | 20 億まで、将来オーバーする可能性 |
UUID | 分散システム | 衝突なし、長い、ソート効率低 |
String | 自然キー(コード等) | 変更困難、ビジネス的に変わると面倒 |
BigInteger | 暗号系・巨大数 | 稀 |
主キーに関する設計指針
- 自然キーより代理キー (id): 変更耐性が高い、JOIN が効率的
- 主キーは不変: 一度設定したら変更しない
- 主キーは公開しない: API では別の識別子(slug, code)を使う設計も検討
- 連番 ID の連番性に依存しない: 抜けがあっても気にしない
- UUID の保存形式: VARCHAR(36) は人間に読みやすい、BINARY(16) は容量・速度効率良い
よくある問題
Q. INSERT が遅い (IDENTITY 戦略)
IDENTITY だとバッチ INSERT が効かない(1 件ずつ ID を取りに行く)。大量 INSERT なら SEQUENCE + allocationSize を大きくする:
@SequenceGenerator(name = "user_seq", sequenceName = "user_seq", allocationSize = 100)
Q. ID が連番にならない
SEQUENCE で allocationSize が大きいと、再起動時に予約 ID 内で抜けが発生します。これは正常動作で、ID 連続性は気にしないべき。
Q. 楽観ロック
@Entity
public class User {
@Id private Long id;
@Version
private Long version; // ← 楽観ロック用バージョン番号
// ...
}
// 同時更新が起きると OptimisticLockingFailureException
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?