KotlinでSQLのJOINを使いこなそう!初心者でも理解できるデータのつなぎ方
生徒
「Kotlinで、複数のテーブルから一緒にデータを取り出すことってできますか?」
先生
「できますよ。そのときに使うのが、SQLのJOIN(ジョイン)という機能です。Kotlinと組み合わせて使うと便利ですよ。」
生徒
「JOINってよく聞くけど、どういう意味なんですか?」
先生
「JOINは、別々のテーブルの情報をくっつける技術です。たとえば『ユーザー』と『注文履歴』を一緒に表示する場面で使います。詳しく見ていきましょう!」
1. KotlinでSQLのJOINを使う理由
現実のアプリ開発では、1つのデータだけを見ることは少なく、複数の情報をまとめて表示する場面がたくさんあります。
たとえば「Aさんがどんな商品を注文したのか」を表示したいとき、「ユーザー情報」と「注文情報」の2つのテーブルが必要になります。
そんなときに役立つのが、JOINです。SQLのJOINをKotlinで使えば、効率よく関連するデータをまとめて取得できます。
2. SQLのJOINとは?
SQLのJOINとは、共通する「カギ(キー)」をもとにして、別々のテーブルのデータをくっつける方法です。
たとえば、次のような2つのテーブルがあるとします。
- usersテーブル:ユーザー情報(id, name)
- ordersテーブル:注文情報(id, user_id, item_name)
このとき、users.idとorders.user_idが共通のカギになって、JOINができます。
3. SQLiteを使ったKotlinでのJOINの例
Kotlinでは、AndroidのアプリなどでSQLiteというデータベースをよく使います。ここではSQLiteを使ったJOINの書き方を紹介します。
■ JOINを使ったSQL文
val query = """
SELECT users.name, orders.item_name
FROM users
INNER JOIN orders ON users.id = orders.user_id
""".trimIndent()
■ KotlinでJOIN結果を取得する方法
val db = readableDatabase
val cursor = db.rawQuery(query, null)
cursor.use {
val nameIndex = cursor.getColumnIndex("name")
val itemIndex = cursor.getColumnIndex("item_name")
while (cursor.moveToNext()) {
val userName = cursor.getString(nameIndex)
val itemName = cursor.getString(itemIndex)
println("ユーザー:$userName, 商品:$itemName")
}
}
4. INNER JOINとは?
INNER JOIN(内部結合)は、両方のテーブルにデータがある場合のみ、結果を返します。
つまり、ユーザー情報があるけど注文がない人や、注文情報があるけどユーザーが不明なデータは、結果に出てきません。
5. LEFT JOINとの違いも覚えよう
LEFT JOIN(左外部結合)を使うと、左側(主となるテーブル)のすべてのデータが表示されます。
注文していないユーザーも一覧に出したい場合は、LEFT JOINを使いましょう。
val query = """
SELECT users.name, orders.item_name
FROM users
LEFT JOIN orders ON users.id = orders.user_id
""".trimIndent()
6. KotlinでJOINを使うときの注意点
- カラム名が同じときは
users.name AS user_nameのように別名(AS)をつけよう - テーブルの結合条件(ON句)を忘れると、想定外の結果になることがあります
- パフォーマンスを意識し、必要なカラムだけ指定しよう(
*は避ける)
7. Kotlin初心者におすすめのJOINの練習方法
初心者のうちは、まずは「1対多」の関係を理解することが大切です。たとえば:
- 1人のユーザーが複数の商品を注文する
- 1つのカテゴリーに複数の商品が属する
このような関係をJOINで表現する練習をすると、Kotlinとデータベースの理解がぐんと深まります。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
8. KotlinでJOINを使うとできること
KotlinとJOINを組み合わせることで、次のような実用的な機能を作れます。
- ユーザーと注文履歴を一覧表示
- 商品とカテゴリを一緒に表示
- ログインユーザーが投稿したコメントだけを取得
JOINをマスターすると、アプリの機能がグッと広がります。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験