Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Databaseのことを考えずにiOSアプリを作る ローカルデータベースを使うときの アーキ...
Search
ムッチョ
March 04, 2024
Programming
250
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Databaseのことを考えずにiOSアプリを作る ローカルデータベースを使うときの アーキテクチャ設計
ムッチョ
March 04, 2024
More Decks by ムッチョ
See All by ムッチョ
AndroidアプリのUIをGeminiで生成する
musayazuju
0
110
Architecture Design for Local Database ~ Realm, CoreData, SwiftData ~
musayazuju
0
140
Generate Android App UI with Gemini
musayazuju
2
170
CoreDataからSwiftDataへの移行
musayazuju
1
190
Other Decks in Programming
See All in Programming
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
200
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
280
エンジニア向け会社紹介/Findy Company Profile
findyinc
6
350k
「AIで開発し、AIを届ける」をEvalでつなぐ 〜AIネイティブに始めるプロダクト開発の実践〜 / Connecting "Develop with AI, deliver AI" with Eval
rkaga
4
5.3k
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
21
6.9k
AI 輔助遺留系統現代化的經驗分享
jame2408
1
910
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
600
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
550
エージェンティックRAGにAWSで入門しよう!
har1101
8
1.7k
Even G2とAWSで推しのエージェントを召喚しよう!
har1101
1
120
さぁV100、メモリをお食べ・・・
nilpe
0
150
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
14
5.7k
Featured
See All Featured
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.9k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.2k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
200
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.3k
The Language of Interfaces
destraynor
162
27k
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
200
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
200
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
1
2k
How to Ace a Technical Interview
jacobian
281
24k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
950
Automating Front-end Workflow
addyosmani
1370
210k
Transcript
Databaseのことを考えずにiOSアプリを作る ローカルデータベースを使うときの アーキテクチャ設計
自己紹介 • ヤズジュムーサー(ムッチョ) • VoicyのiOSエンジニア • Androidもぼちぼちやってます • 趣味はボルダリング Mucchooooo
個人開発もやってます!
ローカルデータベースで 苦労した経験はありますか?
データベースのオブジェクトの扱いには ルールが多い!
例えば... Realm このRealmオブジェクトは普通の変数のよう に取得したり変更したりできない。
考えなきゃいけない ルール • Realmインスタンスの扱い方 • Threadは単一のものを使用しているか • etc. Realmの場合
データベースオブジェクトの扱いに付随するルール はたくさんある Realmの場合 1. threadを跨いでオブジェクトにアクセスするとクラッシュ 2. realm.write {} ブロックの外でrealmオブジェクトを編集するとクラッシュ 3.
モデル定義にないプロパティへアクセスしようとするとクラッシュ 4. 削除済みのRealmオブジェクトにアクセスしようとするとクラッシュ 5. Realmインスタンスを適切にクローズしないとリソースのリークや不正な状態の参照でクラッシュ CoreDataの場合 1. Contextを異なるThread間で共有するとクラッシュ 2. フェッチリクエストが完了する前に結果セットにアクセスしようとするとクラッシュ 3. モデル定義にないエンティティにアクセスしようとするとクラッシュ 4. 削除されたか、コンテキストに属していないマネージドオブジェクトを操作するとクラッシュ 5. モデルの属性に対して予期しない型のデータを設定しようとするとクラッシュ 6. コンパイルされたモデルとコード内のモデルが一致しない場合クラッシュ
データベースオブジェクトの扱いに付随するルール はたくさんある Realmの場合 1. threadを跨いでオブジェクトにアクセスするとクラッシュ 2. realm.write {} ブロックの外でrealmオブジェクトを編集するとクラッシュ 3.
モデル定義にないプロパティへアクセスしようとするとクラッシュ 4. 削除済みのRealmオブジェクトにアクセスしようとするとクラッシュ 5. Realmインスタンスを適切にクローズしないとリソースのリークや不正な状態の参照でクラッシュ CoreDataの場合 1. Contextを異なるThread間で共有するとクラッシュ 2. フェッチリクエストが完了する前に結果セットにアクセスしようとするとクラッシュ 3. モデル定義にないエンティティにアクセスしようとするとクラッシュ 4. 削除されたか、コンテキストに属していないマネージドオブジェクトを操作するとクラッシュ 5. モデルの属性に対して予期しない型のデータを設定しようとするとクラッシュ 6. コンパイルされたモデルとコード内のモデルが一致しない場合クラッシュ ルールを守るのは 難しい・苦労する
ルールに違反していても、コンパイルエ ラーが起きない上、コードから違反箇所を 見つけることは難しい。 開発者かユーザーがクラッシュするまで 見つけられない可能性も
データベースオブジェクトの ルールは 品質的にも脅威 開発効率的にも脅威
データベースのオブジェクトを 普通の変数のように自由に扱いたい!
Solution 1.データベース用のオブジェクトと普通のオ ブジェクトを用意する Normal Object Realm Object
2.オブジェクト同士を 変換できる状態にする Normal Object Realm Object
3. Realm Serviceを用意 データベースに関わる処理を担当 Realmに依存しないCard配列を 他の全てのファイルで使う
4.アプリ起動時にRealm ObjectをFetchして Normal Objectに変換 RealmCard情報をfetchして Card配列に変換
Card配列に少しでも変更があると syncronizeWithRealm() が呼ばれる バックグラウンドスレッドにて Card配列をRealmCardに変換し、 情報をRealmデータに適用 4.Normal Objectが変更された時 Realm Objectが自動で変更される状態を作る
普通の使い方の場合 Realm Card
普通の使い方の場合 Realm Cardを扱う全てのファイル (View, ViewModel, Testファイルなど) がRealmに依存する+ルールに従う義務を負う Realm Card
今回のアーキテクチャの場合 起動時のFetch・Cardへの変換 Cardが変更されるたび自動でRealmに保存 Realm Card Card Realm Service
今回のアーキテクチャの場合 起動時のFetch・Cardへの変換 Cardが変更されるたび自動でRealmに保存 アプリ全体ではRealmに一切依存しないCardクラスが使われるため、 RealmService以外の全てのファイルがRealmに依存しない。 Realmのことを一切考えずに開発ができる! Realm Card Card Realm
Service
今回紹介したアーキテクチャの メリット 1. 保守性・開発効率の向上! ルールから脱却!データベースのことを考えずに開発ができる! 2. 最高レベルのUIパフォーマンスを達成できる! データの更新は常にバックグラウンド。 データ量が膨大になるとローカルデータベースでも重くなりがちだが、いつでも超高速 3.
テストも書きやすくなる+動作も高速! テストの実行がデータベースに依存しない 。パラレル実行なども簡単。 4. コード全体がデータベースに依存しない。 もしデータベースを変更するとしても書き直しが少ない。
まとめ データベースのオブジェクトは デリケートなアイテム 直に触れることは避けるのがベター
デメリット、コード、詳しい解説は Zennにあります! https://zenn.dev/voicy/articles/dd42bfbee7de01
ありがとうございました!