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.
→
terahide
February 21, 2015
Technology
35
0
Share
データモデルは時空を越える
2015/2/21 しょぼちむにデータモデル設計について教えてくださいの会 #syoboben
terahide
February 21, 2015
More Decks by terahide
See All by terahide
アニメに学ぶチームの多様性とコンピテンシー
terahide
0
650
テスト駆動開発でダイエットに挑戦して失敗した話
terahide
0
1.3k
コミュニケーション不全はなぜ起きるか
terahide
0
160
オレオレになりがちなテスト計画を見直した話
terahide
0
180
和服を普段着にするようになって気づいたアジャイルの心
terahide
0
46
Management3.0のワークを受けてから会社の偉い人へM3.0のワークショップをするまでにやったこと
terahide
0
150
一番アジャイルな料理人はソーマくんだと思うんだ
terahide
0
88
Att
terahide
0
40
受託開発でテストファーストしたらXXXを早期発見できてハイアジリティになったはなし
terahide
0
46
Other Decks in Technology
See All in Technology
色を視る
yuzneri
0
320
生成AIはソフトウェア開発の革命か、ソフトウェア工学の宿題再提出なのか -ソフトウェア品質特性の追加提案-
kyonmm
PRO
2
820
独断と偏見で試してみる、 シングル or マルチエージェント どっちがいいの?
shichijoyuhi
1
240
データ定義の混乱と戦う 〜 管理会計と財務会計 〜
wonohe
0
180
VespaのParent Childを用いたフィードパフォーマンスの改善
taking
0
240
Google Cloud Next '26 の裏でこっそりリリースされたCloud Number Registry & Cloud Hub コスト分析 を試してみた
hikaru1001
0
150
巨大プラットフォームを進化させる「第3のROI」
recruitengineers
PRO
2
2.3k
[Oracle TechNight#99] 生成AI時代のAI/ML入門 ~ AIとオラクルデータベースの関係 (前半)
oracle4engineer
PRO
2
210
Modernizing Your HCL Connections Experience: Visual Report to chain, Profile Enhancements, and AI Integration
wannesrams
0
270
AI駆動開発で生産性を追いかけたら、行き着いたのは品質とシフトレフトだった
littlehands
0
310
Oracle Exadata Database Service on Cloud@Customer X11M (ExaDB-C@C) サービス概要
oracle4engineer
PRO
2
7.9k
『生成AI時代のクレデンシャルとパーミッション設計 — Claude Code を起点に』の執筆企画
takuros
2
2.1k
Featured
See All Featured
Abbi's Birthday
coloredviolet
2
7.4k
The Language of Interfaces
destraynor
162
26k
エンジニアに許された特別な時間の終わり
watany
106
240k
Tell your own story through comics
letsgokoyo
1
910
New Earth Scene 8
popppiees
3
2.2k
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
780
Balancing Empowerment & Direction
lara
6
1.1k
Building AI with AI
inesmontani
PRO
1
960
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
500
Transcript
てらひで 2015/2/21 #syoboben データモデルは 時空を超える!? ~移動する情報と追跡可能性~
てらひで @terahide27 認定スクラムマスター 認定スクラム プロダクトオーナー アジャイルコンサルタント アーキテクト
てらひで @terahide27 http://gigazine.net/news/20141206-anime-2015winter/ 深夜アニメの カバレッジ90%以上
今日お話すること •データモデルってなんだっ け? •履歴と更新 •データと移動
やらないこと •むずかしいお話 •詳しい説明 •アニメのお話
データ モデル
データ - Wikipedia 伝達、解釈、処理などに適するように形式 化、符号化されたもの、または再度情報 として解釈できるものをいう。 -snip- 端的に言うと、意味のあるデータが 「情報」となる。→情報 http://ja.wikipedia.org/wiki/%E3%83%87%E3%83%BC%E3%82%BF
モデル - Wikipedia -snip- システムやプロセスに関して、計算や予測 の助けとするために、単純化した記述のこ とで、特に数学的なそれのこと[1]。現実 よりも単純化した説明 →モデル (学術)、
数理モデル。 http://ja.wikipedia.org/wiki/%E3%83%A2%E3%83%87%E3%83%AB
データモデル 意味のあるデータ= 『情報』 を 単純化した記述のこと
今日のお題1 つぶやきシステム
ここ! 35,582回ツイート 35,582件の履歴
簡単なモデル ユーザ ツイート 1 0..*
履歴 ツイート 値 更新日時
履歴 おまけ ツイート 変更履歴 1..* 1
今日のお題2 受発注 むずかしい (>_<)
整理 •データ – 注文、発注、商品、などなど •やりたいこと – 注文があった商品を発注先へ納品する – 二重出荷、未出荷などの誤出荷はNG •考えること
– 倉庫に商品がなかったらどうなるんだろう? – などなど
やり方 •一番細かい単位でデータを保持 –トランザクションの単位 •すべての履歴を残す
Sample 注文 * 1 明細 商品 個数 値 1 *
※いろいろ割愛 明細を更新する 可能性のある 最少単位で
使いづらい (>_<)
なにが起こるか •更新はCreateとDeleteだけになる •参照はがっちゃんこしてみればいい
用法容量を お守りの上 適切にお使い ください
性能には気 を付けてね
•時間(現在・過去・未来の受注) •空間(倉庫から発送先へ) つまり移動! 時空を超える
TEA •AccountPattern –アナリシスパターン(ISBN:4894716933) •絶版orz •Transaction(トランザクション) •Entry(エントリー) •Account(資源)
資源 移動の対象となるもの 名前 :商品 商品名:みかん 単位 :箱 個数 :在庫数+入荷数ー出荷数
エントリー 資源をどのくらい変更したか 個数:30 個数:-1 入荷の時 出荷の時
ここまで エントリー 資源 * 1
トランザクション どこからどこへ移動したか 名前:入荷 名前:出荷 入荷は 入荷元から 倉庫への移動 出荷は 倉庫から 出荷先への移動
ここまで エントリー 資源 * 1 トランザク ション * 1
倉庫には今いくつみかん箱がありますか? 質問 1 30箱 2 -1箱 3 -3箱 エントリー 26箱
資源 1 入荷 2 出荷 3 出荷 トランザクション
今日のお題1 つぶやきシステム
つぶやき ツイート 変更 ツイート <Account> <Entry> * 1 ツイート 変更
<Transaction> 1 1 ※冗長だね
つぶやき ツイート変更 ツイート <Account> <Entry> クソモデルw 1 追加 クソモデルw *
1
つぶやき ツイート変更 ツイート <Account> <Entry> 天使モデル 1 追加 クソモデルw 2
変更 天使モデル * 1
つぶやき ツイート変更 ツイート <Account> <Entry> 1 追加 クソモデルw 2 変更
天使モデル 3 削除 * 1 天使モデル
履歴 ツイート 値 更新日時
ご参考 •オージス総研 アナパタ勉強会のページ –第6章 在庫管理と会計 -前半- http://www.ogis-ri.co.jp/otc/hiroba/others/AnaPatStudy/
まとめ •データモデルはテーブル設計 とは限らない •履歴を残そう •更新を無くそう •必要があればトレーサビリティ にも気を使おう
われわれに よい 学びの場を 与えてくださった しょぼちむはえらい 拍手!