カテゴリ: Kotlin 更新日: 2025/12/27

Kotlinでデータベースのテーブルを定義する方法を徹底解説!初心者にもわかるEntityアノテーションの使い方

Kotlinでデータベースのテーブルを定義する方法(Entityアノテーション)
Kotlinでデータベースのテーブルを定義する方法(Entityアノテーション)

先生と生徒の会話形式で理解しよう

生徒

「Kotlinでデータベースのテーブルを作るには、どうすればいいんですか?」

先生

「Kotlinでは、@Entityというアノテーションを使って、クラスをテーブルとして定義します。」

生徒

「アノテーションって何ですか?難しそう…」

先生

「安心して。アノテーションは、クラスや関数に“特別な意味”を伝えるためのマークのようなものです。難しい仕組みは後回しで、まずは使い方から覚えていきましょう。」

1. Kotlinでデータベース操作をする準備

1. Kotlinでデータベース操作をする準備
1. Kotlinでデータベース操作をする準備

Kotlinでデータベースを操作するためには、ORM(Object Relational Mapping)という仕組みを使います。これは、Kotlinのクラスと、データベースのテーブルを結びつける技術です。

その中でもよく使われるのが、RoomHibernateです。今回は、初心者でも使いやすい「Roomライブラリ」を例に説明します。

2. @Entityアノテーションとは?

2. @Entityアノテーションとは?
2. @Entityアノテーションとは?

@Entity(エンティティ)は、Kotlinのクラスを「データベースのテーブルですよ」と教えるマークです。クラスの上にこのアノテーションをつけることで、そのクラスがテーブルとして扱われるようになります。

例えば、「ユーザー情報」を保存したい場合は、次のようなクラスを定義します。


import androidx.room.Entity
import androidx.room.PrimaryKey

@Entity(tableName = "users")
data class User(
    @PrimaryKey val id: Int,
    val name: String,
    val email: String
)

3. 各アノテーションの意味をやさしく解説

3. 各アノテーションの意味をやさしく解説
3. 各アノテーションの意味をやさしく解説
  • @Entity:このクラスは「users」という名前のテーブルに対応しています。
  • @PrimaryKeyidがテーブルの主キー(ユニークな値)であることを示します。
  • data class:Kotlinの「データを扱うための特別なクラス」です。自動で便利な処理が追加されます。

たとえば、上のクラスではidが「会員番号」のようなもので、重複しない値として使われます。

4. テーブル名を自由に決める方法

4. テーブル名を自由に決める方法
4. テーブル名を自由に決める方法

@Entityには、tableNameというオプションをつけることができます。これを使うと、テーブル名を自由に設定できます。設定しない場合は、クラス名がそのままテーブル名になります。


@Entity(tableName = "custom_table_name")
data class Item(
    @PrimaryKey val id: Int,
    val title: String
)

5. 主キー(Primary Key)とは何かを解説

5. 主キー(Primary Key)とは何かを解説
5. 主キー(Primary Key)とは何かを解説

主キー(Primary Key)とは、データベースの中で一意に(=重複せず)そのデータを特定するための番号やIDのことです。

例えば、生徒の名簿があったとき、「生徒番号」があれば同じ名前の人がいても区別できますよね。それと同じです。

Kotlinでは、主キーにする変数の前に@PrimaryKeyをつけるだけでOKです。

6. 自動採番する主キーにするには?

6. 自動採番する主キーにするには?
6. 自動採番する主キーにするには?

毎回手動でIDを設定するのは大変ですよね。RoomではautoGenerate = trueを使うと、自動で番号をふってくれます。


@Entity
data class Book(
    @PrimaryKey(autoGenerate = true) val id: Int,
    val title: String,
    val author: String
)

このように書くと、新しい本のデータを追加したときに、自動でidが増えていく仕組みになります。

7. カラム名を自由に設定する方法

7. カラム名を自由に設定する方法
7. カラム名を自由に設定する方法

デフォルトでは、変数名がそのままカラム名になります。でも、カラム名をもっと分かりやすくしたいときは、@ColumnInfoを使って変更できます。


import androidx.room.ColumnInfo

@Entity
data class Product(
    @PrimaryKey val id: Int,
    @ColumnInfo(name = "product_name") val name: String,
    @ColumnInfo(name = "product_price") val price: Int
)

これで、データベース上では「product_name」「product_price」という名前でカラムが作られます。

8. Kotlinのクラスがそのままテーブルになる仕組み

8. Kotlinのクラスがそのままテーブルになる仕組み
8. Kotlinのクラスがそのままテーブルになる仕組み

ここまで学んだ通り、クラスにアノテーションをつけるだけで、データベースのテーブルを作る準備が整います。

これは、「Kotlinで書いたクラスの設計図」が、「データベース上の表(テーブル)」になるということです。実際にデータを保存・取得したいときは、別の仕組みを使いますが、まずはこのEntity(エンティティ)でテーブルを定義するのが第一歩です。

カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のオブジェクト指向の特徴を完全ガイド!初心者でも理解できる他言語との違い
New2
Go言語
Go言語の条件分岐の見やすい書き方を徹底解説!初心者でもわかるif文の使い方
New3
Kotlin
Kotlinのクラス設計に役立つベストプラクティスまとめ|初心者でもわかるクラス設計の考え方
New4
Kotlin
Kotlinでアーキテクチャ設計の基本!MVC・MVP・MVVMの違いを解説
人気記事
No.1
Java&Spring記事人気No1
Go言語
Go言語の関数パラメータ!値渡しと参照渡しの違いを理解しよう
No.2
Java&Spring記事人気No2
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.3
Java&Spring記事人気No3
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.4
Java&Spring記事人気No4
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.5
Java&Spring記事人気No5
Kotlin
Kotlinのインストール方法まとめ!Windows・Mac・Linux別にステップ解説
No.6
Java&Spring記事人気No6
Go言語
Go言語のWebアプリにおけるセキュリティベストプラクティス集
No.7
Java&Spring記事人気No7
Kotlin
Kotlinの演算子一覧と使い方!算術・比較・論理演算子の基本を解説
No.8
Java&Spring記事人気No8
Swift
Swiftのオプショナル型とは?初心者でもわかる使い方とアンラップの基礎