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
概念モデル→論理モデルで気をつけていること
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
sunnyone
September 08, 2025
Programming
530
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
概念モデル→論理モデルで気をつけていること
sunnyone
September 08, 2025
More Decks by sunnyone
See All by sunnyone
multirange 型(多重範囲型)の活用
sunnyone
0
110
開発者とのコミュニケーションのはじめかた
sunnyone
0
60
印象に残ったLLMの使い方5選
sunnyone
0
38
シンプルじゃないテーブルの見つけ方
sunnyone
1
380
Next.js App Router登場後の話
sunnyone
0
83
はやい開発のためのJSONデータ型の活用
sunnyone
0
190
フロントエンドトレンドのふりかえりと事業に合わせた選択
sunnyone
0
120
メタプログラミングとは
sunnyone
0
2.6k
RustからPythonを呼び出す
sunnyone
1
4.8k
Other Decks in Programming
See All in Programming
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.2k
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
130
IBM Bobを活用したレガシーアプリの最新化
oniak3ibm
PRO
1
180
柔軟なPDFレイアウトエディタを支える型システム設計 — Discriminated UnionとConditional Typeの実践
minako__ph
4
1.5k
JJUG CCC 2026 Spring: JSpecify で実現する Kotlin フレンドリーな Java API 設計
ternbusty
1
140
tsserverとは何だったのか、これからどうなるのか
nowaki28
1
450
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
500
JavaDoc 再入門
nagise
0
300
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
310
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
110
AI時代の仕事技芸論 — ソフトウェア開発で「遊ぶように働く」職人的熟達のすすめ
kuranuki
1
620
Lessons from Spec-Driven Development
simas
PRO
0
140
Featured
See All Featured
How to build a perfect <img>
jonoalderson
1
5.6k
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
220
Practical Orchestrator
shlominoach
191
11k
jQuery: Nuts, Bolts and Bling
dougneiner
66
8.5k
Speed Design
sergeychernyshev
33
1.8k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
23k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.3k
The Cult of Friendly URLs
andyhume
79
6.9k
Technical Leadership for Architectural Decision Making
baasie
3
400
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
360
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
150
Transcript
概念モデル→論理モデルで気をつけていること @_sunnyone / 2025-09-13 at 中国地方DB 勉強会 1
自己紹介 Yoichi Imai (@_sunnyone) / Web アプリケーションエンジニア フロントエンド、DB 、インフラ DB
ユーザー歴: PostgreSQL 7.4, 8 〜9.6 くらい、12 くらい、14 〜 MySQL 5.7 Oracle のことは忘れました 2
宣伝 mcp-postgres-dump-schema を作りました。 https://zenn.dev/sunnyone/articles/7a138fc004731b 3
今日話すこと 目次 データモデル(概念、論理、物理)について 概念モデルを論理モデルに落とすステップ Tips ActiveRecord パターンに親しんだアプリケーション開発者をターゲ ットにしたRDB の設計の話です 4
データモデルの抽象度 階層 概要 概念データ モデル 業務の「ものごと」と関係の洗い出し、言葉合わせ。 論理データ モデル RDB に載せられる形への整理。主キー/
外部キー、一意 性、正規化等、多重度の明確化等。 物理データ モデル 実装に配慮した構造の調整 5
概念モデルを論理モデルに落とすステップ 6
概念(しかも雑な状態)の例 例えば、日毎に読書本数を記録する例が概念モデルの中にあったとす る。 読書本数 ユーザーID: 整数 観測⽇: ⽇付 本数: 整数
7
イベントを見出して分離する たいていリソースからイベントが見出されてないので、イベントを見 出す。イベントとリソースのイメージを作る。 8
読書本数の例 読書本数の場合、何冊読んだかの情報を入力するというイベントが考 えられる。これが妥当な場合、以下のように分割できる。 読書本数 ユーザーID: 整数 観測⽇: ⽇付 本数: 整数
読書本数⼊⼒ 9
ライフサイクルの違いを確認する 読書本数は今回の前提から日毎。一方で、読書本数の入力は日に1 回 と限らない(訂正したり、一気に入力したりする) 読書本数 ユーザーID: 整数 観測⽇: ⽇付 本数:
整数 読書本数⼊⼒ ユーザーID: 整数 ⼊⼒⽇時: ⽇時 10
実際に必要な項目を埋める・分割する 論理構造まで考え始めると、記録する箇所が足りないことがある。今 回の例では、読書本数の入力が日の単位ではないので、読書本数とは 別のテーブルが必要になる。 読書本数 ユーザーID: 整数 観測⽇: ⽇付 本数:
整数 読書本数⼊⼒ ユーザーID: 整数 ⼊⼒⽇時: ⽇時 読書本数⼊⼒_本数 観測⽇: ⽇付 本数: 整数 足したものは、リソースの場合とイベントの場合がある。 11
イベントとリソースの関連を検討する データ量やイベントの重要度によって、リソースとイベントの関連の させ方が異なる。 イベントの項目をID でポイントする ビューを作ってイベントを見る 重複保存する 12
Tips 13
単一責任に配慮して分割する 概念モデルの段階では複数の責務がひとつのクラスにある場合がある ので、このタイミングで分割する。 例えば、家庭の消耗品{ティッシュ残量,洗剤残量}のようなモデル が雑にあった場合、ティッシュの残量と洗剤の残量を同一テーブルと して記録するのが適切でない可能性がある。 14
データのライフサイクルの違いを意識して分割 する ライフサイクルの違いも配慮して分割する。 例えば、ざっくり概念で睡眠記録{入眠時刻,起床時刻}があったと する。このままが適切な場合もあるが、寿命が異なる場合がある(例 えば入眠時刻のみ先に記録など)ので、適切に対処する。 15
イベント→リソースの参照はおかしいことが多 い イベントは特性上消えないことが多いが、リソースは消えたり更新さ れたりするので、イベント→リソースの参照は不適切なことが多い。 16
命名でリソース側かイベント側かわかるように する リソースかイベントかでざっくり違った配慮が出てくる。 例えば、イベントは追記で削除しない等。 配慮の違いを認識しやすいので、同一のリソースを扱うためのテーブ ルは、イベントのくくりなのかリソースのくくりなのか名前でわかる ようにしておくと便利。 例えば、 「本」と「本_ 売却」など。
17
階層を混乱させる命名はしない リソースの名前に修飾されることが多くなるので、命名がどうしても 長くなりがち。 しかし、下手に省略すると階層が変わってしまうことがあり、後の解 読に影響を及ぼすので注意する。 木をたどるような命名、例えばa_b_c のようなつけかたをするケース で、a_c のように名付けると c
がa の子のように誤認してしまう。 18
Key やFK が変なときはテーブルに過不足がある 関連を考える際に、適切なリレーションが張れない場合、必要なテー ブルが足りなかったり、変な階層に存在していたりすることが多い。 過不足や階層の整理が不十分であることを疑う。 19