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

KotlinのRoomでデータ取得する方法を完全解説!初心者向け@Queryの使い方

KotlinのRoomでデータを取得する基本クエリ(@Query)の書き方
KotlinのRoomでデータを取得する基本クエリ(@Query)の書き方

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

生徒

「Kotlinでアプリのデータベースから情報を取り出すには、どうすればいいんですか?」

先生

「KotlinでAndroidアプリを作るときは、『Room(ルーム)』という仕組みを使ってデータベースとやり取りできます。その中で『@Query(アットクエリ)』という注釈を使うと、データを取り出せますよ。」

生徒

「なんだか難しそうですが、実際にはどんなふうに使うんですか?」

先生

「では、KotlinのRoomでの基本的な@Queryの使い方を、順番にわかりやすく解説していきましょう!」

1. Roomとは?データベースとやり取りする仕組み

1. Roomとは?データベースとやり取りする仕組み
1. Roomとは?データベースとやり取りする仕組み

Room(ルーム)は、KotlinでAndroidアプリを作るときに使われる「データベース操作の便利セット」です。専門的には「ライブラリ」といって、データを保存したり読み出したりする処理を簡単にしてくれる道具です。

Roomを使えば、複雑なSQL文(エスキューエル:データベースと会話するための文)をほとんど書かずに、データを読み書きできます。

2. @Queryとは?Roomでデータを取り出す魔法のカギ

2. @Queryとは?Roomでデータを取り出す魔法のカギ
2. @Queryとは?Roomでデータを取り出す魔法のカギ

@Queryは、Roomで使う特別な「注釈(アノテーション)」です。アノテーションとは、Kotlinのコードに「これはこういう意味ですよ」と教えてあげる目印のようなものです。

@Queryを使うことで、SQLの命令を直接書いてデータを取り出せます。例えば、「全てのデータを取得したい」「名前が"太郎"の人だけ取り出したい」など、柔軟に指定できます。

3. KotlinでのRoom + @Query の基本的な使い方

3. KotlinでのRoom + @Query の基本的な使い方
3. KotlinでのRoom + @Query の基本的な使い方

ここでは、名前と年齢を持つ人の情報を保存する簡単な例で、@Queryの基本を学びます。

① データクラス(エンティティ)を定義

まずは、データの形を定義します。


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

@Entity(tableName = "users")
data class User(
    @PrimaryKey(autoGenerate = true) val id: Int = 0,
    val name: String,
    val age: Int
)

② DAOインターフェースで@Queryを書く

DAO(ダオ)とは「データとやり取りする窓口」です。この中で@Queryを使います。


import androidx.room.Dao
import androidx.room.Query

@Dao
interface UserDao {

    // 全てのユーザーを取得
    @Query("SELECT * FROM users")
    fun getAllUsers(): List<User>

    // 特定の名前のユーザーを取得
    @Query("SELECT * FROM users WHERE name = :userName")
    fun getUsersByName(userName: String): List<User>

    // 年齢が20歳以上のユーザーだけ取得
    @Query("SELECT * FROM users WHERE age >= :minAge")
    fun getAdultUsers(minAge: Int): List<User>
}

4. @Queryでよく使う条件と記号の意味

4. @Queryでよく使う条件と記号の意味
4. @Queryでよく使う条件と記号の意味

Roomで使うSQL文の中には、条件を指定するための記号が出てきます。初心者が迷いやすいものをいくつか紹介します。

  • =(イコール): 値が等しいことを意味します。例:name = :userName
  • >=(以上): 数字が指定値以上のとき。例:age >= 20
  • LIKE(ライク): あいまい検索。例:name LIKE '%郎'(「〜郎」で終わる名前)

5. データ取得結果の例を見てみよう

5. データ取得結果の例を見てみよう
5. データ取得結果の例を見てみよう

例えば、次のようなデータが保存されていたとします。


    1 | 太郎 | 25
    2 | 次郎 | 17
    3 | 花子 | 30

このとき、getAdultUsers(20) を呼び出すと、次の2件が取得されます。


    1 | 太郎 | 25
    3 | 花子 | 30

6. 注意点:SQL文はスペルミスに注意!

6. 注意点:SQL文はスペルミスに注意!
6. 注意点:SQL文はスペルミスに注意!

@Queryでは、SQL文を自分で書く必要があります。たとえば SELET(×)のように SELECT(○)の綴りを間違えると、アプリが起動しなかったり、ビルドエラーになります。

また、テーブル名やカラム名(列の名前)も、定義とピッタリ同じでないとエラーになります。

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

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

※ Amazon広告リンク

7. Kotlin + Room + @Query は覚えておいて損なし!

7. Kotlin + Room + @Query は覚えておいて損なし!
7. Kotlin + Room + @Query は覚えておいて損なし!

KotlinでAndroidアプリを作るなら、Roomと@Queryは避けて通れない基本です。最初は難しそうに見えても、少しずつ慣れていけば大丈夫です。

実際のアプリでも、「買い物リスト」「ユーザー情報」「日記の記録」など、どんな場面でもデータ取得は欠かせません。

関連セミナーのご案内

【未経験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言語
Swiftの文字列操作を完全ガイド!初心者でもわかるStringの基本
No.5
Java&Spring記事人気No5
Go言語
Go言語のSQLインジェクション対策を完全解説!初心者でも安全なデータベース操作がわかる
No.6
Java&Spring記事人気No6
Kotlin
KotlinのRoomで複雑なクエリを使いこなす!初心者でもわかる応用テクニック
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!
No.8
Java&Spring記事人気No8
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方