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

KotlinのRoomでデータベースマイグレーションを行う基本手順を初心者向けに解説!

KotlinのRoomのデータベースマイグレーションの基本
KotlinのRoomのデータベースマイグレーションの基本

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

生徒

「KotlinのRoomを使っていて、後からテーブルのカラムを追加したいときってどうすればいいんですか?」

先生

「そのときに使うのが『データベースマイグレーション』という方法です。Roomでは、バージョンアップに合わせて正しくデータを移行することができますよ。」

生徒

「それって難しそうですが、具体的にどんなことをするんですか?」

先生

「それでは、KotlinでRoomのマイグレーションをする基本的な流れを、分かりやすく説明していきましょう!」

1. Roomのデータベースマイグレーションとは?

1. Roomのデータベースマイグレーションとは?
1. Roomのデータベースマイグレーションとは?

マイグレーションとは、古いバージョンのデータベースを新しい形に変える処理のことです。

たとえば、アプリのバージョン1では「名前と年齢」しかなかったけれど、バージョン2では「メールアドレス」も保存したくなったとします。こういうときに、すでにインストール済みの人のデータを壊さずに新しい構造に変えるための手順が「マイグレーション」です。

2. マイグレーションが必要になる場面とは?

2. マイグレーションが必要になる場面とは?
2. マイグレーションが必要になる場面とは?

Roomを使ったアプリでは、データベースのversionを上げたときに、過去のデータと新しい構造の整合性が必要になります。

  • カラム(列)を追加した
  • テーブルを新しく作った
  • テーブル名を変更した

これらの変更を正しくアプリに反映するには、マイグレーション処理を設定する必要があります。

3. KotlinのRoomでマイグレーションする基本の書き方

3. KotlinのRoomでマイグレーションする基本の書き方
3. KotlinのRoomでマイグレーションする基本の書き方

ここでは、ユーザーテーブルに「email」というカラムを追加する例で、Roomのマイグレーション処理を見てみましょう。

① 新しいエンティティを作る


@Entity(tableName = "users")
data class User(
    @PrimaryKey val id: Int,
    val name: String,
    val age: Int,
    val email: String // 新しく追加されたカラム
)

② データベースバージョンを上げる

RoomDatabaseのversionを1から2に上げます。


@Database(entities = [User::class], version = 2)
abstract class AppDatabase : RoomDatabase() {
    abstract fun userDao(): UserDao
}

③ Migrationオブジェクトを定義する


val MIGRATION_1_2 = object : Migration(1, 2) {
    override fun migrate(database: SupportSQLiteDatabase) {
        database.execSQL("ALTER TABLE users ADD COLUMN email TEXT NOT NULL DEFAULT ''")
    }
}

④ Roomのビルダーにマイグレーションを追加する


val db = Room.databaseBuilder(
    context,
    AppDatabase::class.java, "my_database"
).addMigrations(MIGRATION_1_2).build()

4. execSQLって何?

4. execSQLって何?
4. execSQLって何?

execSQLは、データベースに直接SQL文(命令文)を送る関数です。Roomの裏ではSQLite(エスキューライト)という仕組みが動いており、execSQLを使ってテーブルの形を変更します。

「カラムを追加する」には、ALTER TABLE テーブル名 ADD COLUMN カラム名 型 DEFAULT 初期値 という命令を使います。

5. DEFAULTの設定を忘れずに!

5. DEFAULTの設定を忘れずに!
5. DEFAULTの設定を忘れずに!

新しくカラムを追加するとき、すでに入っている古いデータにはそのカラムがありません。だからこそ、初期値(DEFAULT)を必ずつける必要があります。

例えば、emailを追加したけど、今までのデータにはメールアドレスがない…というとき、''(空文字)を入れておくことでエラーを防げます。

6. バージョン番号は必ず1ずつ上げよう

6. バージョン番号は必ず1ずつ上げよう
6. バージョン番号は必ず1ずつ上げよう

Roomのマイグレーションでは、versionを飛び越えることはできません。たとえば、バージョン1から3にするには、

  • MIGRATION_1_2
  • MIGRATION_2_3

のように順番に設定する必要があります。ひとつひとつの段階を丁寧に用意していきましょう。

Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。

基礎からわかるKotlinをAmazonで見る

※ Amazon広告リンク

7. マイグレーションを使えばデータを壊さずアップデートできる

7. マイグレーションを使えばデータを壊さずアップデートできる
7. マイグレーションを使えばデータを壊さずアップデートできる

KotlinとRoomを使ってアプリを作ると、あとから「もっと情報を保存したい」と思うことがよくあります。

そんなときでも、マイグレーションを正しく設定しておけば、ユーザーの大切なデータを消すことなく、新しい形に安全に更新できます。

初心者のうちは怖く感じるかもしれませんが、流れさえ分かれば意外とシンプルです。何度も練習して慣れていきましょう。

関連セミナーのご案内

【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分

「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。

本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。

具体的な体験内容と環境

【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。

【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。

この60分で得られる3つの体験

1. 自分のパソコンが「開発基地」に

プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。

2. プログラミングの「仕組み」がスッキリ

「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。

3. 「読みやすい」から「直せる」へ

Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。

※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。

セミナー画像

Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験

関連記事:
カテゴリの一覧へ
新着記事
New1
Swift
Swiftのnilとは?Optionalとの関係や初期化について初心者向けにやさしく解説!
New2
Go言語
Go言語のinit関数の役割と使い方!プログラム起動時の初期化処理
New3
Go言語
Go言語のマップの順序保証がない理由と扱い方の工夫をやさしく解説!初心者でもわかる基本知識
New4
Kotlin
Kotlinのforループの基本!範囲・配列・コレクションの繰り返し処理
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.2
Java&Spring記事人気No2
Go言語
Swiftの配列(Array)の使い方を完全ガイド!初心者でもわかるデータのまとめ方
No.3
Java&Spring記事人気No3
Swift
Swiftの高階関数map・filter・reduceを完全解説!初心者でもわかる配列操作の基本
No.4
Java&Spring記事人気No4
Go言語
Go言語のSQLインジェクション対策を完全解説!初心者でも安全なデータベース操作がわかる
No.5
Java&Spring記事人気No5
Go言語
Swiftの文字列操作を完全ガイド!初心者でもわかるStringの基本
No.6
Java&Spring記事人気No6
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!
No.7
Java&Spring記事人気No7
Kotlin
KotlinのRoomで複雑なクエリを使いこなす!初心者でもわかる応用テクニック
No.8
Java&Spring記事人気No8
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方