Submit Search
Upload
ドメイン駆動設計 ~ユーザー、モデル、エンジニアの新たな関係~
•
49 likes
•
25,431 views
啓 杉本
Follow
2015/10/3 PHPカンファレンスのPHPメンターズトラックにおけるプレゼンテーション
Read less
Read more
Engineering
Report
Share
Report
Share
1 of 20
Download now
Download to read offline
Recommended
ドメイン駆動設計 本格入門
ドメイン駆動設計 本格入門
増田 亨
ドメイン駆動設計入門
ドメイン駆動設計入門
Takuya Kitamura
ツール比較しながら語る O/RマッパーとDBマイグレーションの実際のところ
ツール比較しながら語る O/RマッパーとDBマイグレーションの実際のところ
Y Watanabe
AngularとSpring Bootで作るSPA + RESTful Web Serviceアプリケーション
AngularとSpring Bootで作るSPA + RESTful Web Serviceアプリケーション
ssuser070fa9
例外設計における大罪
例外設計における大罪
Takuto Wada
ドメイン駆動設計 at DDD.rb #5
ドメイン駆動設計 at DDD.rb #5
啓 杉本
ドメイン駆動設計のための Spring の上手な使い方
ドメイン駆動設計のための Spring の上手な使い方
増田 亨
ドメイン駆動設計 ( DDD ) をやってみよう
ドメイン駆動設計 ( DDD ) をやってみよう
増田 亨
Recommended
ドメイン駆動設計 本格入門
ドメイン駆動設計 本格入門
増田 亨
ドメイン駆動設計入門
ドメイン駆動設計入門
Takuya Kitamura
ツール比較しながら語る O/RマッパーとDBマイグレーションの実際のところ
ツール比較しながら語る O/RマッパーとDBマイグレーションの実際のところ
Y Watanabe
AngularとSpring Bootで作るSPA + RESTful Web Serviceアプリケーション
AngularとSpring Bootで作るSPA + RESTful Web Serviceアプリケーション
ssuser070fa9
例外設計における大罪
例外設計における大罪
Takuto Wada
ドメイン駆動設計 at DDD.rb #5
ドメイン駆動設計 at DDD.rb #5
啓 杉本
ドメイン駆動設計のための Spring の上手な使い方
ドメイン駆動設計のための Spring の上手な使い方
増田 亨
ドメイン駆動設計 ( DDD ) をやってみよう
ドメイン駆動設計 ( DDD ) をやってみよう
増田 亨
Tackling Complexity
Tackling Complexity
Yoshitaka Kawashima
テスト文字列に「うんこ」と入れるな
テスト文字列に「うんこ」と入れるな
Kentaro Matsui
イベント・ソーシングを知る
イベント・ソーシングを知る
Shuhei Fujita
イミュータブルデータモデルの極意
イミュータブルデータモデルの極意
Yoshitaka Kawashima
オブジェクト指向の設計と実装の学び方のコツ
オブジェクト指向の設計と実装の学び方のコツ
増田 亨
SPAセキュリティ入門~PHP Conference Japan 2021
SPAセキュリティ入門~PHP Conference Japan 2021
Hiroshi Tokumaru
3週連続DDDその2 深いモデルの探求(ドメイン駆動設計 第3部)
3週連続DDDその2 深いモデルの探求(ドメイン駆動設計 第3部)
増田 亨
DDD x CQRS 更新系と参照系で異なるORMを併用して上手くいった話
DDD x CQRS 更新系と参照系で異なるORMを併用して上手くいった話
Koichiro Matsuoka
イミュータブルデータモデル(入門編)
イミュータブルデータモデル(入門編)
Yoshitaka Kawashima
オブジェクト指向できていますか?
オブジェクト指向できていますか?
Moriharu Ohzu
ドメイン駆動設計 の 実践 Part3 DDD
ドメイン駆動設計 の 実践 Part3 DDD
増田 亨
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
Takuto Wada
「実践ドメイン駆動設計」 から理解するDDD (2018年11月)
「実践ドメイン駆動設計」 から理解するDDD (2018年11月)
A AOKI
ドメイン駆動設計の実践例 - 経営管理基盤 fusion_place -
ドメイン駆動設計の実践例 - 経営管理基盤 fusion_place -
啓 杉本
ドメイン駆動設計サンプルコードの徹底解説
ドメイン駆動設計サンプルコードの徹底解説
増田 亨
ドメインロジックに集中せよ 〜ドメイン駆動設計 powered by Spring
ドメインロジックに集中せよ 〜ドメイン駆動設計 powered by Spring
増田 亨
今こそ知りたいSpring Batch(Spring Fest 2020講演資料)
今こそ知りたいSpring Batch(Spring Fest 2020講演資料)
NTT DATA Technology & Innovation
シリコンバレーの「何が」凄いのか
シリコンバレーの「何が」凄いのか
Atsushi Nakada
Azure DevOpsとセキュリティ
Azure DevOpsとセキュリティ
Kazushi Kamegawa
ビジネスルールの複雑さに立ち向かう
ビジネスルールの複雑さに立ち向かう
増田 亨
財管一致について~財務会計と管理会計の関係性~
財管一致について~財務会計と管理会計の関係性~
啓 杉本
ドメイン特化プラットフォームによる業務システム開発体制の変革
ドメイン特化プラットフォームによる業務システム開発体制の変革
啓 杉本
More Related Content
What's hot
Tackling Complexity
Tackling Complexity
Yoshitaka Kawashima
テスト文字列に「うんこ」と入れるな
テスト文字列に「うんこ」と入れるな
Kentaro Matsui
イベント・ソーシングを知る
イベント・ソーシングを知る
Shuhei Fujita
イミュータブルデータモデルの極意
イミュータブルデータモデルの極意
Yoshitaka Kawashima
オブジェクト指向の設計と実装の学び方のコツ
オブジェクト指向の設計と実装の学び方のコツ
増田 亨
SPAセキュリティ入門~PHP Conference Japan 2021
SPAセキュリティ入門~PHP Conference Japan 2021
Hiroshi Tokumaru
3週連続DDDその2 深いモデルの探求(ドメイン駆動設計 第3部)
3週連続DDDその2 深いモデルの探求(ドメイン駆動設計 第3部)
増田 亨
DDD x CQRS 更新系と参照系で異なるORMを併用して上手くいった話
DDD x CQRS 更新系と参照系で異なるORMを併用して上手くいった話
Koichiro Matsuoka
イミュータブルデータモデル(入門編)
イミュータブルデータモデル(入門編)
Yoshitaka Kawashima
オブジェクト指向できていますか?
オブジェクト指向できていますか?
Moriharu Ohzu
ドメイン駆動設計 の 実践 Part3 DDD
ドメイン駆動設計 の 実践 Part3 DDD
増田 亨
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
Takuto Wada
「実践ドメイン駆動設計」 から理解するDDD (2018年11月)
「実践ドメイン駆動設計」 から理解するDDD (2018年11月)
A AOKI
ドメイン駆動設計の実践例 - 経営管理基盤 fusion_place -
ドメイン駆動設計の実践例 - 経営管理基盤 fusion_place -
啓 杉本
ドメイン駆動設計サンプルコードの徹底解説
ドメイン駆動設計サンプルコードの徹底解説
増田 亨
ドメインロジックに集中せよ 〜ドメイン駆動設計 powered by Spring
ドメインロジックに集中せよ 〜ドメイン駆動設計 powered by Spring
増田 亨
今こそ知りたいSpring Batch(Spring Fest 2020講演資料)
今こそ知りたいSpring Batch(Spring Fest 2020講演資料)
NTT DATA Technology & Innovation
シリコンバレーの「何が」凄いのか
シリコンバレーの「何が」凄いのか
Atsushi Nakada
Azure DevOpsとセキュリティ
Azure DevOpsとセキュリティ
Kazushi Kamegawa
ビジネスルールの複雑さに立ち向かう
ビジネスルールの複雑さに立ち向かう
増田 亨
What's hot
(20)
Tackling Complexity
Tackling Complexity
テスト文字列に「うんこ」と入れるな
テスト文字列に「うんこ」と入れるな
イベント・ソーシングを知る
イベント・ソーシングを知る
イミュータブルデータモデルの極意
イミュータブルデータモデルの極意
オブジェクト指向の設計と実装の学び方のコツ
オブジェクト指向の設計と実装の学び方のコツ
SPAセキュリティ入門~PHP Conference Japan 2021
SPAセキュリティ入門~PHP Conference Japan 2021
3週連続DDDその2 深いモデルの探求(ドメイン駆動設計 第3部)
3週連続DDDその2 深いモデルの探求(ドメイン駆動設計 第3部)
DDD x CQRS 更新系と参照系で異なるORMを併用して上手くいった話
DDD x CQRS 更新系と参照系で異なるORMを併用して上手くいった話
イミュータブルデータモデル(入門編)
イミュータブルデータモデル(入門編)
オブジェクト指向できていますか?
オブジェクト指向できていますか?
ドメイン駆動設計 の 実践 Part3 DDD
ドメイン駆動設計 の 実践 Part3 DDD
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
SQLアンチパターン 幻の第26章「とりあえず削除フラグ」
「実践ドメイン駆動設計」 から理解するDDD (2018年11月)
「実践ドメイン駆動設計」 から理解するDDD (2018年11月)
ドメイン駆動設計の実践例 - 経営管理基盤 fusion_place -
ドメイン駆動設計の実践例 - 経営管理基盤 fusion_place -
ドメイン駆動設計サンプルコードの徹底解説
ドメイン駆動設計サンプルコードの徹底解説
ドメインロジックに集中せよ 〜ドメイン駆動設計 powered by Spring
ドメインロジックに集中せよ 〜ドメイン駆動設計 powered by Spring
今こそ知りたいSpring Batch(Spring Fest 2020講演資料)
今こそ知りたいSpring Batch(Spring Fest 2020講演資料)
シリコンバレーの「何が」凄いのか
シリコンバレーの「何が」凄いのか
Azure DevOpsとセキュリティ
Azure DevOpsとセキュリティ
ビジネスルールの複雑さに立ち向かう
ビジネスルールの複雑さに立ち向かう
Similar to ドメイン駆動設計 ~ユーザー、モデル、エンジニアの新たな関係~
財管一致について~財務会計と管理会計の関係性~
財管一致について~財務会計と管理会計の関係性~
啓 杉本
ドメイン特化プラットフォームによる業務システム開発体制の変革
ドメイン特化プラットフォームによる業務システム開発体制の変革
啓 杉本
6製品1サービスの開発にPortfolio for JIRAを使ってみた
6製品1サービスの開発にPortfolio for JIRAを使ってみた
Hiroshi Ohnuki
Ossを使ったazureでのdev ops
Ossを使ったazureでのdev ops
裕貴 荒井
Small Language Model Local Launch on AI Tour Tokyo
Small Language Model Local Launch on AI Tour Tokyo
Takao Tetsuro
ElasticBeanstalkで作るPHP実行環境
ElasticBeanstalkで作るPHP実行環境
Naoyuki Funatsu
Azure DevOps × スクラム で実現するプロダクト開発のポイント #dotnetlab #jazug
Azure DevOps × スクラム で実現するプロダクト開発のポイント #dotnetlab #jazug
満徳 関
cloudpack監視・運用保守のなかで生まれた自社開発の取り組みと知見
cloudpack監視・運用保守のなかで生まれた自社開発の取り組みと知見
shuichi takahashi
20111014説明会資料(勉強会)
20111014説明会資料(勉強会)
株式会社インサイト
Salesforce DUG meetup09 summer15
Salesforce DUG meetup09 summer15
Ikou Sanuki
yokyo-unv.
yokyo-unv.
hirano
connpass特徴と開発の流れ
connpass特徴と開発の流れ
Ikeda Yosuke
ヤフー発のメッセージキュー「Pulsar」のご紹介
ヤフー発のメッセージキュー「Pulsar」のご紹介
Yahoo!デベロッパーネットワーク
ヤフー発のメッセージキュー 「Pulsar」のご紹介@jjug ccc 20171118
ヤフー発のメッセージキュー 「Pulsar」のご紹介@jjug ccc 20171118
Nozomi Kurihara
20130302 わんくま勉強会大阪 tfsを使ってみよう
20130302 わんくま勉強会大阪 tfsを使ってみよう
Takuya Kawabe
SAP HANAは 単なるインメモリーデータベースじゃなくて (賢い)アプリの開発・実行プラットフォーム
SAP HANAは 単なるインメモリーデータベースじゃなくて (賢い)アプリの開発・実行プラットフォーム
Makoto Sugishita
お店のディスプレイ広告効果をインスタグラムで効果測定する-
お店のディスプレイ広告効果をインスタグラムで効果測定する-
tomomi kawakami
【#osh2014】これからのつながる開発環境とその秘訣 (仮)
【#osh2014】これからのつながる開発環境とその秘訣 (仮)
智治 長沢
20140717 awssummit2014-cloud-operation
20140717 awssummit2014-cloud-operation
Yasuhiro Araki, Ph.D
CakePHP × 国産! baserCMS3の深化と今後の拡がり
CakePHP × 国産! baserCMS3の深化と今後の拡がり
Daisuke Abe
Similar to ドメイン駆動設計 ~ユーザー、モデル、エンジニアの新たな関係~
(20)
財管一致について~財務会計と管理会計の関係性~
財管一致について~財務会計と管理会計の関係性~
ドメイン特化プラットフォームによる業務システム開発体制の変革
ドメイン特化プラットフォームによる業務システム開発体制の変革
6製品1サービスの開発にPortfolio for JIRAを使ってみた
6製品1サービスの開発にPortfolio for JIRAを使ってみた
Ossを使ったazureでのdev ops
Ossを使ったazureでのdev ops
Small Language Model Local Launch on AI Tour Tokyo
Small Language Model Local Launch on AI Tour Tokyo
ElasticBeanstalkで作るPHP実行環境
ElasticBeanstalkで作るPHP実行環境
Azure DevOps × スクラム で実現するプロダクト開発のポイント #dotnetlab #jazug
Azure DevOps × スクラム で実現するプロダクト開発のポイント #dotnetlab #jazug
cloudpack監視・運用保守のなかで生まれた自社開発の取り組みと知見
cloudpack監視・運用保守のなかで生まれた自社開発の取り組みと知見
20111014説明会資料(勉強会)
20111014説明会資料(勉強会)
Salesforce DUG meetup09 summer15
Salesforce DUG meetup09 summer15
yokyo-unv.
yokyo-unv.
connpass特徴と開発の流れ
connpass特徴と開発の流れ
ヤフー発のメッセージキュー「Pulsar」のご紹介
ヤフー発のメッセージキュー「Pulsar」のご紹介
ヤフー発のメッセージキュー 「Pulsar」のご紹介@jjug ccc 20171118
ヤフー発のメッセージキュー 「Pulsar」のご紹介@jjug ccc 20171118
20130302 わんくま勉強会大阪 tfsを使ってみよう
20130302 わんくま勉強会大阪 tfsを使ってみよう
SAP HANAは 単なるインメモリーデータベースじゃなくて (賢い)アプリの開発・実行プラットフォーム
SAP HANAは 単なるインメモリーデータベースじゃなくて (賢い)アプリの開発・実行プラットフォーム
お店のディスプレイ広告効果をインスタグラムで効果測定する-
お店のディスプレイ広告効果をインスタグラムで効果測定する-
【#osh2014】これからのつながる開発環境とその秘訣 (仮)
【#osh2014】これからのつながる開発環境とその秘訣 (仮)
20140717 awssummit2014-cloud-operation
20140717 awssummit2014-cloud-operation
CakePHP × 国産! baserCMS3の深化と今後の拡がり
CakePHP × 国産! baserCMS3の深化と今後の拡がり
ドメイン駆動設計 ~ユーザー、モデル、エンジニアの新たな関係~
1.
ドメイン駆動設計 ユーザー、モデル、エンジニアの 新たな関係 PHPメンターズセミナー in PHPカンファレンス Oct.3, 2015 杉本
啓 twitter: @sugimoto_kei http://www.fusions.co.jp
2.
自己紹介 • 会計事務所系コンサルティング会社(アクセンチュア/アンダーセン)出身。 • 生産管理/会計系基幹システム構築
(スクラッチ開発, SAP R/3等) ~ 会計・経営管理領域の制度設計・業務改革 ~ パッケージソフト(連結会計)開発など。 • 2003年独立、経営管理基盤ソフトウェア「fusion_place」の開発販売・導入支援。 http://www.fusions.co.jp • 現役 Java プログラマ。OOPラブ × XPラブ × DOAラブ。 • 全然アップデートしていないブログあり。 http://hot-heart-cool-mind.seesaa.net/ • 「IT勉強宴会」で時々おしゃべり & いつも Drink! http://www.benkyoenkai.org/ <日経BP谷島さんによる紹介記事> http://business.nikkeibp.co.jp/article/campanella/20141016/272649/
3.
1. ドメイン駆動設計とは 2. ドメイン駆動設計の3つの原則 3.
3つの原則からみたDDD本の構成 4. ドメインとドメインモデル 5. ドメインモデルとは何か 6. ドメインに浸潤するドメインモデル 7. DDDの2つの「ひねり」 8. DDDとDOAの同型性 9. DDDとオブジェクト指向 10. DDDの適用領域 11. DDDの拡張可能性 12. ドメイン・エンジニアリング ~DDDの射程~ 目次
4.
「ドメイン駆動設計」とは ・・・根本的には、DDDを駆動している原則は次の3つだけです。 コアドメインに集中すること。 ドメインの実践者とソフトウェアの実践者による創造的な共同 作業を通じて、モデルを探求すること。 明示的な境界づけられたコンテキストの内部で、 ユビキタス言語を語ること。 DDD本(※)「日本語版への序文」by エリック・エヴァンス (※)エリック・エヴァンス, 2011年,「エリック・エヴァンスのドメイン駆動設計」翔泳社、以下同
5.
ドメイン駆動設計の3つの原則 ユビキタス 言語 モデル駆動 設計 (※)DDD本 表表紙と裏表紙のパターン関連図 適用範囲の選択 に関する原則 適用範囲での設計のあり方 に関する原則 コアドメイン 本日は、主に下側の2つの原則について考察します。 3つの原則のうち、2つ(ユビキタス言語とモデル駆動設計)は、原著発刊時 に書かれたパターン関連図(※)で中核に位置付けられている。 「コアドメイン」は、中核には位置付けられていなかったが、本文を読むと、 当初から重視されていたことがわかる。
6.
3つの原則からみたDDD本の構成 第1部 ドメインモデルを機能させる ⇒ユビキタス言語とモデル駆動の紹介 第2部
モデル駆動設計の構成要素 ⇒モデルと実装の結び付け方 第3部 より深い洞察に向かうリファクタリング ⇒モデルを洗練させる方法 第4部 戦略的設計 ⇒コアドメインへの集中の強調と、集中のための具体的手法 DDD本の構成 第2部の位置づけが難しい。 第2部を中心に読むと: オブジェクト指向の適用パターン本に見える。 その割には、内容に新味がない(2003年の原著発刊時点でも)。 とはいえ、多くの現場で出来ていないのは確かなので、啓蒙的効果はある。 でも、それでは、ユビキタス言語とモデル駆動を強調する意味がわからない...
7.
ドメイン・ドメインモデル・モデル駆動・ユビキタス言語の意味を、 あらためて、考えてみましょう。
8.
《質問》 ドメインモデルはドメインのモデルなのでしょうか?
9.
ドメインとドメインモデル 例: ソースコード管理システム ドメイン (問題領域) ソース コード 管理 Subversion Git 「コミット」の意味 「コミット」という言葉は、ドメインモデルの一部のはずですが... 「コミット」の定義はドメインにではなく、ツールに依存する。
ソースコード管理システムが世に現れて初めて「コミット」という言葉 が「リポジトリへの変更登録」という意味で使われ始めた。 セントラルリポジトリへの 変更登録 (登録時に競合があり得る) ローカルリポジトリへの 変更登録 (登録ににの競合はあり得ないが、別途、 push などでリポジトリ間同期必要) ツール (解決領域)
10.
ドメインモデルとは何か(1/2) ドメインモデルは: こちらではなく... ...こちらではないでしょうか。 問題領域(ドメイン)のモデル。 解決領域(ツール)のモデル。 但し、ソフトの内部構造ではなく、 ユーザも理解すべき、情報処理のモデル。 あらかじめ存在する、分析対象。
ソリューションの開発に際して、 意図的に設計する対象。 ドメイン・エキスパートが 知っている。 ドメイン・エキスパートの知見を踏 まえながら、我々エンジニアも考え る。 ドメインモデルは、ソリューションのモデル。 そしてエンジニアリングの結果、生まれるものである。
11.
ドメインモデルとは何か(2/2) DDD本では、船舶/コンテナが登場するモデルと、 船荷証券等が登場するモデルの差異を、深さの違いと捉えているが、 モデル化の対象が異なると考えた方が適切。 事業における、 具体的な活動。 事業活動を制御する 管理/統制活動。 モデル化対象 船舶 コンテナ 本船・次航 (vessel voyage) 船荷証券(B/L) DDD本での例 (p. 191-192) 【参考】 DOAでの呼称例(※) 事業過程 管理過程 「浅いモデル」 情報とその動き ヒト・モノ・カネ とその動き 「深いモデル」 (※)
佐藤正美, 2005年,「データベース設計論-T字形ER」, ソフト・リサーチ・センター、p.34-35 ドメインモデルは事業活動自体のモデルではなく、事業活動を支える情報処理 のモデル。両者は必ずしも一致しない。 《 問 題 領 域 》 《 解 決 領 域 》 事業活動の モデル ドメイン モデル モデル 相互依存
12.
ドメインに浸潤するドメインモデル 情報処理(解決領域)のモデルであるドメインモデルが、ドメイン(問題領 域)のモデルであるかのように見られがちなのは、多くのドメインが、ドメイ ンモデルにより浸潤されているから。 ドメイン 浸潤しているドメインモデル 会計 複式簿記
本来的には帳簿記録を組織化するためのひとつ の手法・パターンに過ぎない。 貿易 船荷証券 貿易慣行の中で確立され、法制度化された、取 引に関する事務処理パターン。 鉄道運行 ダイヤ 運行スケジュールを線引きするために工夫され た手書き図(ダイヤグラム)。これも事業活動 をサポートするための情報処理パターン。 モデリング UML モデリング自体は図的表記がなくとも可。UML でなくとも可。 ドメインモデルは情報処理のモデルだから、 コンピュータの登場以前に成立/普及している場合もある。 これらは容易に、ドメインそのものと混同されてしまう。
13.
二元的モデルと三元的モデル OOA※で一般的な モデル観 (DDD本 p.46) 分析モデル 設計モデル 問題領域/分析対象(=与件)
解決領域/設計対象 ドメインモデル の導入 事業活動の モデル プログラム構造 のモデル ドメイン モデル DDDの モデル観 (私見) 事業活動の モデル プログラム構造 のモデル ドメイン モデル ドメインモデル=ユビキタス言語 (単一のモデル) DDDのモデル観は一周回って二元的モデルに戻っているが、 境界線の位置が一般的なOOAとは異なっている。(私見) ※ オブジェクト指向分析
14.
DDDの2つの「ひねり」 DDDの 「ひねり」 2つの「ひねり」によって、DDDは、エンジニアリングの対象領域を広げつつ、 エンジニアリング活動内部の分裂を防止しようとしている(私見)。 事業活動のモデルと ドメインモデルの切り離し ドメインモデルと プログラム構造の統合 「ユビキタス言語」 「モデル駆動アプローチ」 ドメインモデルを、ユーザ所 有物から共同所有物に転化す る。 ドメインモデルとソースコー ドの乖離によるドメインモデ ルの形骸化を防ぐ。 DDDでは、以下の2つの「ひねり」を通じて「境界線の引き替え」を行って いる。
15.
DDDとDOAの同型性 DDDの 「ひねり」 DDDとDOA、根本的な発想は共通で、 実装に適用するパラダイム※とアプローチが異なる。 事業活動のモデルと ドメインモデルの切り離し ドメインモデルと プログラム構造の統合 当然の認識 佐藤正美:事業過程/管理過程 渡辺幸三:データモデルは帳簿組織 DSLによるドメインモデル 記述に基づく 自動生成/動的制御で対応 (モダンな)DOAでは... DOAは、ソフトウェア開発というより業務システム開発の現場で育ってきたた め、2つの「ひねり」は、むしろ当然の前提(当然過ぎて議論に上りにくい)。 ※ 分析や設計に適用する枠組み・文法
16.
DDDとオブジェクト指向 ユビキタス 言語 モデル駆動 設計 コア ドメイン エンティティ 値オブジェクト サービス … 原則レイヤのパターン群 実践レイヤのパターン群 オブジェクト指向には、 依存していない。 オブジェクト指向に 依存している部分が相当ある。 特に、ユビキタス言語の文法を 提示している第2章のパターン 群。 DDD本は、実践レイヤのパラダイムとしてオブジェクト指向を採用しているが、 DDDの原則自体はオブジェクト指向から独立している。 DDDは全体としてパターン言語を形成している。この言語は、「原則」レイ ヤと「実践」レイヤに分かつことが出来る。
17.
DDDの適用領域 DDD本は、エヴァンス氏の経験から生まれた。その経験は以下のようなプロ ジェクトを通じて培われたものである(DDD本「エピローグ」)。 1. 商用のPCB(プリント基板)設計用ソフトウェア 2. 複数の金融機関が利用するローンソフトウェア 3.
大手国際輸送会社の輸送業務システム 4. 商用の在庫管理ソフトウェア いずれも、継続的開発が当然で、汎用性や柔軟性を重視した設計が 見合う(コスト合理性がある)ケース。 3カ月で稼働/納品して後は最小限のメンテしかされないソフトではない。 4つのうち3つが商用パッケージソフトウェア。 残りひとつ(3)は、開発した企業の戦略的優位性の中核にあるようなソフト。
18.
DDDの拡張可能性 DDDの原則はそのままに、プラクティス(実践手法)を入れ替えることで、 DDD自体を拡張できると思われる。 ユビキタス 言語 モデル駆動 コア ドメイン オブジェクト指向 リレーショナルモデル 多次元データモデル DDD本の DDD (モダンな)DOA (
≒超高速開発※2) DDD on fusion_place … … 汎用言語 DSL(※1) DSL (※1) DSL=ドメイン特化言語 (※2) 「超高速開発」は、開発が速くなることに価値を見出した呼称ですが、DDDの文脈ではむしろ、設計/開発の フォーカスをドメインモデルの(再)設計に移すことに価値を求めることが可能と思われます。 中核パラダイム 記述言語水準 開発アプローチ
19.
ドメイン・エンジニアリング ~ DDDの射程 ~ ドメインモデルを設計対象とするなら、我々は、ユーザとともに業務や取引の 方式を設計することも出来る。システム設計はもっとクリエイティブになる。 ドメイン
ドメインモデルパターン 販売/生産管理 ・MRPを代替/補完する「在庫推移監視方式」。 (※) 会計/経営管理 ・複式簿記の拡張形としての「増減複式簿記」。 ・複雑化する管理会計/財務報告に適した「二層帳簿モデル」。 ・変化する経営環境に追随する「環境適応型予算管理モデル」。 DDDの「原則」は、 DDD本が示している「実践」より、はるかに広く遠い射程を 持っているのではないでしょうか。 http://hot-heart-cool-mind.seesaa.net/article/393131426.html http://hot-heart-cool-mind.seesaa.net/article/393131365.html http://www.fusions.co.jp/mail-magazine/mm-003/ (※) 渡辺幸三, 2002年,「生産管理・原価管理のためのデータモデリング」, 日本実業出版社、p.188
20.
終わり
Download now