Kotlinでデータベースのテーブルを定義する方法を徹底解説!初心者にもわかるEntityアノテーションの使い方
生徒
「Kotlinでデータベースのテーブルを作るには、どうすればいいんですか?」
先生
「Kotlinでは、@Entityというアノテーションを使って、クラスをテーブルとして定義します。」
生徒
「アノテーションって何ですか?難しそう…」
先生
「安心して。アノテーションは、クラスや関数に“特別な意味”を伝えるためのマークのようなものです。難しい仕組みは後回しで、まずは使い方から覚えていきましょう。」
1. Kotlinでデータベース操作をする準備
Kotlinでデータベースを操作するためには、ORM(Object Relational Mapping)という仕組みを使います。これは、Kotlinのクラスと、データベースのテーブルを結びつける技術です。
その中でもよく使われるのが、RoomやHibernateです。今回は、初心者でも使いやすい「Roomライブラリ」を例に説明します。
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. 各アノテーションの意味をやさしく解説
- @Entity:このクラスは「users」という名前のテーブルに対応しています。
- @PrimaryKey:
idがテーブルの主キー(ユニークな値)であることを示します。 - data class:Kotlinの「データを扱うための特別なクラス」です。自動で便利な処理が追加されます。
たとえば、上のクラスではidが「会員番号」のようなもので、重複しない値として使われます。
4. テーブル名を自由に決める方法
@Entityには、tableNameというオプションをつけることができます。これを使うと、テーブル名を自由に設定できます。設定しない場合は、クラス名がそのままテーブル名になります。
@Entity(tableName = "custom_table_name")
data class Item(
@PrimaryKey val id: Int,
val title: String
)
5. 主キー(Primary Key)とは何かを解説
主キー(Primary Key)とは、データベースの中で一意に(=重複せず)そのデータを特定するための番号やIDのことです。
例えば、生徒の名簿があったとき、「生徒番号」があれば同じ名前の人がいても区別できますよね。それと同じです。
Kotlinでは、主キーにする変数の前に@PrimaryKeyをつけるだけでOKです。
6. 自動採番する主キーにするには?
毎回手動でIDを設定するのは大変ですよね。RoomではautoGenerate = trueを使うと、自動で番号をふってくれます。
@Entity
data class Book(
@PrimaryKey(autoGenerate = true) val id: Int,
val title: String,
val author: String
)
このように書くと、新しい本のデータを追加したときに、自動でidが増えていく仕組みになります。
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」という名前でカラムが作られます。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
8. Kotlinのクラスがそのままテーブルになる仕組み
ここまで学んだ通り、クラスにアノテーションをつけるだけで、データベースのテーブルを作る準備が整います。
これは、「Kotlinで書いたクラスの設計図」が、「データベース上の表(テーブル)」になるということです。実際にデータを保存・取得したいときは、別の仕組みを使いますが、まずはこのEntity(エンティティ)でテーブルを定義するのが第一歩です。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験