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
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
ムッチョ
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
200
Other Decks in Programming
See All in Programming
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
2.2k
技術記事、AIに書かせるか、自分で書くか? 〜それでも私が自分の手で書く理由〜 / #QiitaConference
jnchito
2
1.4k
The NotImplementedError Problem in Ruby
koic
1
880
AIだと陥りがちなJakarta EE最新技術への移行時の落とし穴と解決策
tnagao7
0
120
Creating Composable Callables in Contemporary C++
rollbear
0
160
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
13k
ECSアプリログをFireLensでコスト削減しようとしたけど諦めた話 in Fargate×Node.js
akihisaikeda
2
4.2k
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
4.4k
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
720
Webフレームワークの ベンチマークについて
yusukebe
0
170
AIを活用したE2Eテスト実装効率化のあゆみ / ebisu-mobile-14-kotetu
kotetuco
0
120
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
14
5.7k
Featured
See All Featured
Amusing Abliteration
ianozsvald
1
210
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
1
210
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
1.4k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
230
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
2
220
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
The Invisible Side of Design
smashingmag
301
52k
Building Applications with DynamoDB
mza
96
7.1k
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
170
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
200
Accessibility Awareness
sabderemane
1
140
Test your architecture with Archunit
thirion
1
2.3k
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
ありがとうございました!