@k2works/claude-code-booster 3.2.1 → 3.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/assets/docs/article/index.md +4 -1
- package/lib/assets/docs/article/practical-database-design/index.md +121 -0
- package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -0
- package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -0
- package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -0
- package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -0
- package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -0
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -0
- package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -0
- package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -0
- package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -0
- package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -0
- package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -0
- package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -0
- package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -0
- package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -0
- package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -0
- package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -0
- package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -0
- package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -0
- package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -0
- package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -0
- package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -0
- package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -0
- package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -0
- package/package.json +1 -1
|
@@ -0,0 +1,965 @@
|
|
|
1
|
+
# 第22章:生産管理システムの全体像
|
|
2
|
+
|
|
3
|
+
本章から第4部「生産管理システム」の解説に入ります。まず、生産管理システムのスコープと、関連する組織の役割分担について解説します。
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## 22.1 生産管理システムのスコープ
|
|
8
|
+
|
|
9
|
+
生産管理システムは、製造業における「モノづくり」の全工程を管理するシステムです。販売管理システムからの受注情報を起点として、生産計画の立案から製品の完成、在庫管理に至るまでの一連の業務プロセスを管理します。
|
|
10
|
+
|
|
11
|
+
### システム全体像
|
|
12
|
+
|
|
13
|
+
```plantuml
|
|
14
|
+
@startuml
|
|
15
|
+
|
|
16
|
+
title 生産管理システムの全体像
|
|
17
|
+
|
|
18
|
+
rectangle "販売管理" as sales
|
|
19
|
+
rectangle "生産管理" as production {
|
|
20
|
+
rectangle "生産計画" as plan
|
|
21
|
+
rectangle "購買管理" as purchase
|
|
22
|
+
rectangle "製造管理" as manufacturing
|
|
23
|
+
rectangle "在庫管理" as inventory
|
|
24
|
+
rectangle "品質管理" as quality
|
|
25
|
+
rectangle "原価管理" as cost
|
|
26
|
+
}
|
|
27
|
+
rectangle "財務会計" as finance
|
|
28
|
+
|
|
29
|
+
sales --> plan : 受注情報
|
|
30
|
+
plan --> purchase : 購買オーダ
|
|
31
|
+
plan --> manufacturing : 製造オーダ
|
|
32
|
+
purchase --> inventory : 入荷
|
|
33
|
+
manufacturing --> inventory : 完成品
|
|
34
|
+
manufacturing --> quality : 検査依頼
|
|
35
|
+
quality --> inventory : 合格品
|
|
36
|
+
inventory --> sales : 出荷
|
|
37
|
+
cost --> finance : 原価情報
|
|
38
|
+
|
|
39
|
+
@enduml
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
### ユースケース図
|
|
43
|
+
|
|
44
|
+
生産管理システム全体のユースケースは以下の通りです。
|
|
45
|
+
|
|
46
|
+
```plantuml
|
|
47
|
+
@startuml
|
|
48
|
+
left to right direction
|
|
49
|
+
skinparam packageStyle rectangle
|
|
50
|
+
skinparam linetype ortho
|
|
51
|
+
title 生産管理システム ユースケース図
|
|
52
|
+
|
|
53
|
+
actor 営業担当者 as sales
|
|
54
|
+
actor 生産管理担当者 as planner
|
|
55
|
+
actor 購買担当者 as buyer
|
|
56
|
+
actor 製造担当者 as worker
|
|
57
|
+
actor 品質管理担当者 as qa
|
|
58
|
+
actor 倉庫担当者 as warehouse
|
|
59
|
+
|
|
60
|
+
rectangle 生産管理システム {
|
|
61
|
+
usecase "生産計画立案" as UC_PLAN
|
|
62
|
+
usecase "所要量展開(MRP)" as UC_MRP
|
|
63
|
+
usecase "発注管理" as UC_ORDER
|
|
64
|
+
usecase "入荷・検収管理" as UC_RECEIVE
|
|
65
|
+
usecase "製造指示" as UC_WORK
|
|
66
|
+
usecase "製造実績報告" as UC_RESULT
|
|
67
|
+
usecase "在庫管理" as UC_INVENTORY
|
|
68
|
+
usecase "品質管理" as UC_QUALITY
|
|
69
|
+
usecase "原価管理" as UC_COST
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
sales -- UC_PLAN
|
|
73
|
+
planner -- UC_PLAN
|
|
74
|
+
planner -- UC_MRP
|
|
75
|
+
buyer -- UC_ORDER
|
|
76
|
+
buyer -- UC_RECEIVE
|
|
77
|
+
worker -- UC_WORK
|
|
78
|
+
worker -- UC_RESULT
|
|
79
|
+
warehouse -- UC_INVENTORY
|
|
80
|
+
warehouse -- UC_RECEIVE
|
|
81
|
+
qa -- UC_QUALITY
|
|
82
|
+
qa -- UC_RECEIVE
|
|
83
|
+
planner -- UC_COST
|
|
84
|
+
@enduml
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### 生産計画(MPS・MRP)
|
|
88
|
+
|
|
89
|
+
生産計画は、販売計画や受注情報に基づいて、何をいつまでにどれだけ生産するかを決定する業務です。
|
|
90
|
+
|
|
91
|
+
```plantuml
|
|
92
|
+
@startuml
|
|
93
|
+
|
|
94
|
+
state "生産計画業務" as Planning {
|
|
95
|
+
state "販売計画確認" as SalesPlan
|
|
96
|
+
state "MPS作成" as MPS
|
|
97
|
+
state "MRP実行" as MRP
|
|
98
|
+
state "計画調整" as Adjust
|
|
99
|
+
state "計画確定" as Confirm
|
|
100
|
+
|
|
101
|
+
[*] --> SalesPlan
|
|
102
|
+
SalesPlan --> MPS : 需要情報
|
|
103
|
+
MPS --> MRP : 基準生産計画
|
|
104
|
+
MRP --> Adjust : 所要量展開
|
|
105
|
+
Adjust --> Confirm : 調整完了
|
|
106
|
+
Adjust --> MRP : 再計算
|
|
107
|
+
Confirm --> [*]
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
@enduml
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
| 項目 | 説明 |
|
|
114
|
+
|---|---|
|
|
115
|
+
| MPS(基準生産計画) | 製品レベルの生産計画。何をいつまでにいくつ作るか |
|
|
116
|
+
| MRP(所要量展開) | BOM を使って部品・材料レベルまで展開。必要数量と時期を算出 |
|
|
117
|
+
| 主なデータ | オーダ情報、所要情報、引当情報 |
|
|
118
|
+
|
|
119
|
+
### 購買管理(発注・入荷・検収)
|
|
120
|
+
|
|
121
|
+
購買管理は、生産に必要な部品・材料を外部から調達する業務です。
|
|
122
|
+
|
|
123
|
+
```plantuml
|
|
124
|
+
@startuml
|
|
125
|
+
|
|
126
|
+
state "購買管理業務" as Purchasing {
|
|
127
|
+
state "発注" as Order {
|
|
128
|
+
state "発注登録" as OrderCreate
|
|
129
|
+
state "発注確定" as OrderConfirm
|
|
130
|
+
}
|
|
131
|
+
state "入荷" as Receive {
|
|
132
|
+
state "入荷登録" as ReceiveCreate
|
|
133
|
+
state "受入検査" as Inspection
|
|
134
|
+
}
|
|
135
|
+
state "検収" as Accept {
|
|
136
|
+
state "検収登録" as AcceptCreate
|
|
137
|
+
state "在庫計上" as StockIn
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
[*] --> OrderCreate
|
|
141
|
+
OrderCreate --> OrderConfirm
|
|
142
|
+
OrderConfirm --> ReceiveCreate : 入荷
|
|
143
|
+
ReceiveCreate --> Inspection
|
|
144
|
+
Inspection --> AcceptCreate : 合格
|
|
145
|
+
Inspection --> ReceiveCreate : 不合格(返品)
|
|
146
|
+
AcceptCreate --> StockIn
|
|
147
|
+
StockIn --> [*]
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
@enduml
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
| 項目 | 説明 |
|
|
154
|
+
|---|---|
|
|
155
|
+
| 目的 | 生産に必要な部品・材料を適切なタイミングで調達 |
|
|
156
|
+
| 入力 | MRP からの購買オーダ、発注依頼 |
|
|
157
|
+
| 出力 | 発注書、入荷伝票、検収伝票 |
|
|
158
|
+
| 主なデータ | 発注データ、入荷受入データ、検収データ |
|
|
159
|
+
|
|
160
|
+
### 工程管理(製造指示・製造実績)
|
|
161
|
+
|
|
162
|
+
工程管理は、製造オーダに基づいて製造作業を指示し、実績を収集する業務です。
|
|
163
|
+
|
|
164
|
+
```plantuml
|
|
165
|
+
@startuml
|
|
166
|
+
|
|
167
|
+
state "工程管理業務" as Process {
|
|
168
|
+
state "製造指示" as Instruction {
|
|
169
|
+
state "作業指示作成" as WorkOrder
|
|
170
|
+
state "ピッキング" as Picking
|
|
171
|
+
}
|
|
172
|
+
state "製造作業" as Work {
|
|
173
|
+
state "工程作業" as Operation
|
|
174
|
+
state "工程検査" as ProcessInspection
|
|
175
|
+
}
|
|
176
|
+
state "製造実績" as Result {
|
|
177
|
+
state "完成報告" as Complete
|
|
178
|
+
state "工数報告" as LaborReport
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
[*] --> WorkOrder
|
|
182
|
+
WorkOrder --> Picking
|
|
183
|
+
Picking --> Operation
|
|
184
|
+
Operation --> ProcessInspection
|
|
185
|
+
ProcessInspection --> Operation : 不合格
|
|
186
|
+
ProcessInspection --> Complete : 合格
|
|
187
|
+
Complete --> LaborReport
|
|
188
|
+
LaborReport --> [*]
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
@enduml
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
| 項目 | 説明 |
|
|
195
|
+
|---|---|
|
|
196
|
+
| 目的 | 製造オーダを効率的に実行し、実績を正確に記録 |
|
|
197
|
+
| 入力 | 製造オーダ、工程表、BOM |
|
|
198
|
+
| 出力 | 作業指示書、ピッキングリスト、完成報告書 |
|
|
199
|
+
| 主なデータ | 作業指示データ、完成実績データ、工数実績データ |
|
|
200
|
+
|
|
201
|
+
### 在庫管理(受払・在庫状態)
|
|
202
|
+
|
|
203
|
+
在庫管理は、部品・材料・製品の在庫数量と状態を管理する業務です。
|
|
204
|
+
|
|
205
|
+
```plantuml
|
|
206
|
+
@startuml
|
|
207
|
+
|
|
208
|
+
state "在庫管理業務" as Inventory {
|
|
209
|
+
state "入庫" as StockIn
|
|
210
|
+
state "出庫" as StockOut
|
|
211
|
+
state "在庫照会" as Query
|
|
212
|
+
state "棚卸" as Count
|
|
213
|
+
|
|
214
|
+
[*] --> StockIn : 入荷・完成
|
|
215
|
+
[*] --> StockOut : 払出・出荷
|
|
216
|
+
[*] --> Query : 参照
|
|
217
|
+
[*] --> Count : 定期棚卸
|
|
218
|
+
|
|
219
|
+
StockIn --> [*]
|
|
220
|
+
StockOut --> [*]
|
|
221
|
+
Query --> [*]
|
|
222
|
+
Count --> [*]
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
@enduml
|
|
226
|
+
```
|
|
227
|
+
|
|
228
|
+
| 項目 | 説明 |
|
|
229
|
+
|---|---|
|
|
230
|
+
| 目的 | 在庫の正確な把握と適正在庫の維持 |
|
|
231
|
+
| 主な機能 | 在庫照会、受払管理、棚卸、在庫調整 |
|
|
232
|
+
| 主なデータ | 在庫データ、払出データ、棚卸データ |
|
|
233
|
+
|
|
234
|
+
### 品質管理(受入検査・出荷検査・トレーサビリティ)
|
|
235
|
+
|
|
236
|
+
品質管理は、製品の品質を確保するための検査と履歴管理を行う業務です。
|
|
237
|
+
|
|
238
|
+
| 検査種別 | タイミング | 目的 |
|
|
239
|
+
|---|---|---|
|
|
240
|
+
| 受入検査 | 入荷時 | 購入品の品質確認 |
|
|
241
|
+
| 工程検査 | 製造中 | 工程ごとの品質確認 |
|
|
242
|
+
| 出荷検査 | 出荷前 | 最終製品の品質確認 |
|
|
243
|
+
|
|
244
|
+
### 製造原価管理(標準原価・実際原価・配賦)
|
|
245
|
+
|
|
246
|
+
製造原価管理は、製品の製造にかかったコストを計算・管理する業務です。
|
|
247
|
+
|
|
248
|
+
| 原価要素 | 説明 |
|
|
249
|
+
|---|---|
|
|
250
|
+
| 材料費 | 直接材料費、間接材料費 |
|
|
251
|
+
| 労務費 | 直接労務費、間接労務費 |
|
|
252
|
+
| 製造間接費 | 減価償却費、光熱費、間接労務費等 |
|
|
253
|
+
|
|
254
|
+
### マスタ情報とトランザクション情報
|
|
255
|
+
|
|
256
|
+
生産管理システムのデータは、大きく「マスタ情報」と「トランザクション情報」に分類されます。
|
|
257
|
+
|
|
258
|
+
| 分類 | 説明 | 例 |
|
|
259
|
+
|-----|------|-----|
|
|
260
|
+
| **マスタ情報** | 基本的に変更が少ない、システムの基盤となるデータ | 品目マスタ、BOM、取引先マスタ、工程マスタ |
|
|
261
|
+
| **トランザクション情報** | 日々の業務で発生するデータ | 発注データ、製造実績、在庫移動 |
|
|
262
|
+
|
|
263
|
+
---
|
|
264
|
+
|
|
265
|
+
## 22.2 生産組織の役割分担
|
|
266
|
+
|
|
267
|
+
生産管理システムに関わる組織は複数あり、それぞれが異なる役割を担っています。
|
|
268
|
+
|
|
269
|
+
### 組織構成
|
|
270
|
+
|
|
271
|
+
```plantuml
|
|
272
|
+
@startuml
|
|
273
|
+
|
|
274
|
+
package "生産管理に関わる組織" {
|
|
275
|
+
rectangle "営業部" as Sales #LightBlue {
|
|
276
|
+
Sales : ・受注情報の連携
|
|
277
|
+
Sales : ・納期調整
|
|
278
|
+
Sales : ・出荷指示
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
rectangle "生産管理部" as ProdMgmt #LightGreen {
|
|
282
|
+
ProdMgmt : ・生産計画立案
|
|
283
|
+
ProdMgmt : ・MRP 実行
|
|
284
|
+
ProdMgmt : ・進捗管理
|
|
285
|
+
ProdMgmt : ・原価管理
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
rectangle "製造部" as Manufacturing #LightYellow {
|
|
289
|
+
Manufacturing : ・製造作業
|
|
290
|
+
Manufacturing : ・完成報告
|
|
291
|
+
Manufacturing : ・工数報告
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
rectangle "購買部" as Purchasing #LightPink {
|
|
295
|
+
Purchasing : ・発注管理
|
|
296
|
+
Purchasing : ・納期管理
|
|
297
|
+
Purchasing : ・仕入先管理
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
rectangle "外注部" as Outsource #LightCoral {
|
|
301
|
+
Outsource : ・外注発注
|
|
302
|
+
Outsource : ・支給品管理
|
|
303
|
+
Outsource : ・外注進捗管理
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
rectangle "資材倉庫" as MaterialWH #Lavender {
|
|
307
|
+
MaterialWH : ・入荷受入
|
|
308
|
+
MaterialWH : ・部材払出
|
|
309
|
+
MaterialWH : ・在庫管理
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
rectangle "製品倉庫" as ProductWH #LightCyan {
|
|
313
|
+
ProductWH : ・完成品入庫
|
|
314
|
+
ProductWH : ・出荷作業
|
|
315
|
+
ProductWH : ・在庫管理
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
@enduml
|
|
320
|
+
```
|
|
321
|
+
|
|
322
|
+
### 営業部
|
|
323
|
+
|
|
324
|
+
営業部は、得意先との接点を持ち、受注情報を生産管理に連携します。
|
|
325
|
+
|
|
326
|
+
| 業務 | 責務 | 主な操作 |
|
|
327
|
+
|---|---|---|
|
|
328
|
+
| 受注連携 | 受注情報の生産計画への連携 | 受注データ登録 |
|
|
329
|
+
| 納期調整 | 生産計画に基づく納期回答 | 納期回答、納期変更 |
|
|
330
|
+
| 出荷指示 | 製品倉庫への出荷依頼 | 出荷指示登録 |
|
|
331
|
+
|
|
332
|
+
### 生産管理部
|
|
333
|
+
|
|
334
|
+
生産管理部は、生産計画の立案から進捗管理、原価管理までを担当します。
|
|
335
|
+
|
|
336
|
+
| 業務 | 責務 | 主な操作 |
|
|
337
|
+
|---|---|---|
|
|
338
|
+
| 生産計画 | MPS・MRP の立案と調整 | 計画登録、所要量展開 |
|
|
339
|
+
| 進捗管理 | 製造進捗の監視と対応 | 進捗照会、遅延アラート |
|
|
340
|
+
| 原価管理 | 製造原価の計算と分析 | 原価計算、差異分析 |
|
|
341
|
+
|
|
342
|
+
### 製造部
|
|
343
|
+
|
|
344
|
+
製造部は、実際の製造作業を担当します。
|
|
345
|
+
|
|
346
|
+
| 業務 | 責務 | 主な操作 |
|
|
347
|
+
|---|---|---|
|
|
348
|
+
| 製造作業 | 作業指示に基づく製造 | 作業実施 |
|
|
349
|
+
| 完成報告 | 完成数量の報告 | 完成実績登録 |
|
|
350
|
+
| 工数報告 | 作業時間の報告 | 工数実績登録 |
|
|
351
|
+
|
|
352
|
+
### 購買部
|
|
353
|
+
|
|
354
|
+
購買部は、部品・材料の外部調達を担当します。
|
|
355
|
+
|
|
356
|
+
| 業務 | 責務 | 主な操作 |
|
|
357
|
+
|---|---|---|
|
|
358
|
+
| 発注 | 仕入先への発注 | 発注登録、注文書発行 |
|
|
359
|
+
| 納期管理 | 入荷予定の管理 | 納期確認、督促 |
|
|
360
|
+
| 仕入先管理 | 仕入先情報の管理 | 仕入先評価 |
|
|
361
|
+
|
|
362
|
+
### 外注部
|
|
363
|
+
|
|
364
|
+
外注部は、外注加工の管理を担当します。
|
|
365
|
+
|
|
366
|
+
| 業務 | 責務 | 主な操作 |
|
|
367
|
+
|---|---|---|
|
|
368
|
+
| 外注発注 | 外注先への加工依頼 | 外注発注登録 |
|
|
369
|
+
| 支給品管理 | 外注先への支給品管理 | 支給登録、消費確認 |
|
|
370
|
+
| 進捗管理 | 外注作業の進捗管理 | 進捗確認、督促 |
|
|
371
|
+
|
|
372
|
+
### 資材倉庫
|
|
373
|
+
|
|
374
|
+
資材倉庫は、部品・材料の物理的な管理を担当します。
|
|
375
|
+
|
|
376
|
+
| 業務 | 責務 | 主な操作 |
|
|
377
|
+
|---|---|---|
|
|
378
|
+
| 入荷受入 | 購入品の受入と検品 | 入荷登録、検品 |
|
|
379
|
+
| 部材払出 | 製造への部材供給 | 払出登録、ピッキング |
|
|
380
|
+
| 在庫管理 | 在庫数量の管理 | 棚卸、在庫調整 |
|
|
381
|
+
|
|
382
|
+
### 製品倉庫
|
|
383
|
+
|
|
384
|
+
製品倉庫は、完成品の物理的な管理を担当します。
|
|
385
|
+
|
|
386
|
+
| 業務 | 責務 | 主な操作 |
|
|
387
|
+
|---|---|---|
|
|
388
|
+
| 完成品入庫 | 製造からの完成品受入 | 入庫登録 |
|
|
389
|
+
| 出荷作業 | 得意先への出荷 | 出荷登録、配送手配 |
|
|
390
|
+
| 在庫管理 | 製品在庫の管理 | 棚卸、在庫調整 |
|
|
391
|
+
|
|
392
|
+
### 業務フローと各部門の責務
|
|
393
|
+
|
|
394
|
+
各部門がどのタイミングで業務に関与するかを、全体フローで示します。
|
|
395
|
+
|
|
396
|
+
```plantuml
|
|
397
|
+
@startuml
|
|
398
|
+
title 生産管理システムの全体フロー
|
|
399
|
+
|
|
400
|
+
|営業部|
|
|
401
|
+
start
|
|
402
|
+
:受注情報;
|
|
403
|
+
|
|
404
|
+
|生産管理部|
|
|
405
|
+
:生産計画立案;
|
|
406
|
+
:MRP実行;
|
|
407
|
+
fork
|
|
408
|
+
:購買オーダ;
|
|
409
|
+
fork again
|
|
410
|
+
:製造オーダ;
|
|
411
|
+
fork end
|
|
412
|
+
|
|
413
|
+
|購買部|
|
|
414
|
+
:発注登録;
|
|
415
|
+
|
|
416
|
+
|システム|
|
|
417
|
+
:発注データ;
|
|
418
|
+
:注文書;
|
|
419
|
+
|
|
420
|
+
|資材倉庫|
|
|
421
|
+
:入荷受入;
|
|
422
|
+
:受入検査;
|
|
423
|
+
|
|
424
|
+
|購買部|
|
|
425
|
+
:検収登録;
|
|
426
|
+
|
|
427
|
+
|システム|
|
|
428
|
+
fork
|
|
429
|
+
:検収データ;
|
|
430
|
+
fork again
|
|
431
|
+
:在庫データ(入庫);
|
|
432
|
+
fork end
|
|
433
|
+
|
|
434
|
+
|生産管理部|
|
|
435
|
+
:作業指示作成;
|
|
436
|
+
|
|
437
|
+
|システム|
|
|
438
|
+
:作業指示データ;
|
|
439
|
+
:作業指示書;
|
|
440
|
+
:ピッキングリスト;
|
|
441
|
+
|
|
442
|
+
|資材倉庫|
|
|
443
|
+
:部材払出;
|
|
444
|
+
|
|
445
|
+
|製造部|
|
|
446
|
+
:製造作業;
|
|
447
|
+
:完成報告;
|
|
448
|
+
:工数報告;
|
|
449
|
+
|
|
450
|
+
|システム|
|
|
451
|
+
fork
|
|
452
|
+
:完成実績データ;
|
|
453
|
+
fork again
|
|
454
|
+
:工数実績データ;
|
|
455
|
+
fork again
|
|
456
|
+
:在庫データ(完成品入庫);
|
|
457
|
+
fork end
|
|
458
|
+
|
|
459
|
+
|製品倉庫|
|
|
460
|
+
:完成品入庫;
|
|
461
|
+
|
|
462
|
+
|営業部|
|
|
463
|
+
:出荷指示;
|
|
464
|
+
|
|
465
|
+
|製品倉庫|
|
|
466
|
+
:出荷作業;
|
|
467
|
+
|
|
468
|
+
|システム|
|
|
469
|
+
:出荷データ;
|
|
470
|
+
|
|
471
|
+
stop
|
|
472
|
+
|
|
473
|
+
@enduml
|
|
474
|
+
```
|
|
475
|
+
|
|
476
|
+
### 部門間の連携ポイント
|
|
477
|
+
|
|
478
|
+
```plantuml
|
|
479
|
+
@startuml
|
|
480
|
+
|
|
481
|
+
rectangle "営業部" as Sales
|
|
482
|
+
rectangle "生産管理部" as ProdMgmt
|
|
483
|
+
rectangle "製造部" as Manufacturing
|
|
484
|
+
rectangle "購買部" as Purchasing
|
|
485
|
+
rectangle "外注部" as Outsource
|
|
486
|
+
rectangle "資材倉庫" as MaterialWH
|
|
487
|
+
rectangle "製品倉庫" as ProductWH
|
|
488
|
+
|
|
489
|
+
Sales --> ProdMgmt : 受注情報
|
|
490
|
+
ProdMgmt --> Purchasing : 購買オーダ
|
|
491
|
+
ProdMgmt --> Manufacturing : 製造オーダ
|
|
492
|
+
ProdMgmt --> Outsource : 外注オーダ
|
|
493
|
+
|
|
494
|
+
Purchasing --> MaterialWH : 入荷予定
|
|
495
|
+
Outsource --> MaterialWH : 支給指示
|
|
496
|
+
|
|
497
|
+
MaterialWH --> Manufacturing : 部材供給
|
|
498
|
+
Manufacturing --> ProductWH : 完成品
|
|
499
|
+
|
|
500
|
+
ProductWH --> Sales : 出荷可能報告
|
|
501
|
+
|
|
502
|
+
Manufacturing --> ProdMgmt : 進捗報告
|
|
503
|
+
Outsource --> ProdMgmt : 外注進捗
|
|
504
|
+
|
|
505
|
+
@enduml
|
|
506
|
+
```
|
|
507
|
+
|
|
508
|
+
| 連携元 | 連携先 | 連携内容 |
|
|
509
|
+
|---|---|---|
|
|
510
|
+
| 営業部 | 生産管理部 | 受注情報、納期要望 |
|
|
511
|
+
| 生産管理部 | 購買部 | 購買オーダ |
|
|
512
|
+
| 生産管理部 | 製造部 | 製造オーダ、作業指示 |
|
|
513
|
+
| 生産管理部 | 外注部 | 外注オーダ |
|
|
514
|
+
| 購買部 | 資材倉庫 | 入荷予定情報 |
|
|
515
|
+
| 外注部 | 資材倉庫 | 支給指示 |
|
|
516
|
+
| 資材倉庫 | 製造部 | 部材供給 |
|
|
517
|
+
| 製造部 | 製品倉庫 | 完成品 |
|
|
518
|
+
| 製造部 | 生産管理部 | 進捗報告 |
|
|
519
|
+
| 製品倉庫 | 営業部 | 出荷可能報告 |
|
|
520
|
+
|
|
521
|
+
---
|
|
522
|
+
|
|
523
|
+
## 22.3 生産管理システムのアーキテクチャ
|
|
524
|
+
|
|
525
|
+
本節では、生産管理システム(PMS: Production Management System)のプロジェクト構成とアーキテクチャについて解説します。
|
|
526
|
+
|
|
527
|
+
### プロジェクト構成
|
|
528
|
+
|
|
529
|
+
生産管理システムは `apps/pms` ディレクトリ以下に構築します。
|
|
530
|
+
|
|
531
|
+
```
|
|
532
|
+
apps/pms/
|
|
533
|
+
├── backend/
|
|
534
|
+
│ ├── build.gradle.kts # Gradle ビルド設定(Kotlin DSL)
|
|
535
|
+
│ ├── settings.gradle.kts # Gradle 設定
|
|
536
|
+
│ ├── config/ # 品質管理ツール設定
|
|
537
|
+
│ │ ├── checkstyle/
|
|
538
|
+
│ │ │ └── checkstyle.xml
|
|
539
|
+
│ │ ├── pmd/
|
|
540
|
+
│ │ │ └── ruleset.xml
|
|
541
|
+
│ │ └── spotbugs/
|
|
542
|
+
│ │ └── exclude.xml
|
|
543
|
+
│ │
|
|
544
|
+
│ └── src/
|
|
545
|
+
│ ├── main/
|
|
546
|
+
│ │ ├── java/com/example/pms/
|
|
547
|
+
│ │ │ │
|
|
548
|
+
│ │ │ ├── domain/ # ドメイン層(純粋なビジネスロジック)
|
|
549
|
+
│ │ │ │ ├── model/ # ドメインモデル(エンティティ、値オブジェクト)
|
|
550
|
+
│ │ │ │ │ ├── master/ # マスタ関連
|
|
551
|
+
│ │ │ │ │ └── transaction/ # トランザクション関連
|
|
552
|
+
│ │ │ │ ├── type/ # 基本型(通貨、単位、数量等)
|
|
553
|
+
│ │ │ │ └── exception/ # ドメイン例外
|
|
554
|
+
│ │ │ │
|
|
555
|
+
│ │ │ ├── application/ # アプリケーション層
|
|
556
|
+
│ │ │ │ ├── port/
|
|
557
|
+
│ │ │ │ │ ├── in/ # Input Port(ユースケースIF)
|
|
558
|
+
│ │ │ │ │ └── out/ # Output Port(リポジトリIF)
|
|
559
|
+
│ │ │ │ └── service/ # Application Service(ユースケース実装)
|
|
560
|
+
│ │ │ │
|
|
561
|
+
│ │ │ ├── infrastructure/ # インフラストラクチャ層
|
|
562
|
+
│ │ │ │ ├── in/ # Input Adapter
|
|
563
|
+
│ │ │ │ │ └── rest/ # REST API Controller
|
|
564
|
+
│ │ │ │ ├── out/ # Output Adapter
|
|
565
|
+
│ │ │ │ │ └── persistence/ # 永続化(MyBatis Mapper)
|
|
566
|
+
│ │ │ │ └── config/ # 設定クラス
|
|
567
|
+
│ │ │ │
|
|
568
|
+
│ │ │ └── Application.java # メインクラス
|
|
569
|
+
│ │ │
|
|
570
|
+
│ │ └── resources/
|
|
571
|
+
│ │ ├── application.yml # アプリケーション設定
|
|
572
|
+
│ │ ├── db/migration/ # Flyway マイグレーション
|
|
573
|
+
│ │ └── mapper/ # MyBatis XML マッパー
|
|
574
|
+
│ │
|
|
575
|
+
│ └── test/
|
|
576
|
+
│ ├── java/com/example/pms/
|
|
577
|
+
│ │ ├── testsetup/ # テスト基盤クラス
|
|
578
|
+
│ │ │ └── BaseIntegrationTest.java
|
|
579
|
+
│ │ ├── domain/ # ドメイン層テスト
|
|
580
|
+
│ │ ├── application/ # アプリケーション層テスト
|
|
581
|
+
│ │ └── infrastructure/ # インフラ層テスト
|
|
582
|
+
│ │
|
|
583
|
+
│ └── resources/
|
|
584
|
+
│ └── application-test.yml
|
|
585
|
+
│
|
|
586
|
+
└── docker-compose.yml # Docker 構成
|
|
587
|
+
```
|
|
588
|
+
|
|
589
|
+
**各レイヤーの責務:**
|
|
590
|
+
|
|
591
|
+
| レイヤー | 責務 |
|
|
592
|
+
|---|---|
|
|
593
|
+
| Domain 層 | ビジネスルールとドメインモデル(外部技術に非依存) |
|
|
594
|
+
| Application 層 | ユースケースの実装とオーケストレーション |
|
|
595
|
+
| Infrastructure 層 | 外部技術との接続(DB、Web 等) |
|
|
596
|
+
|
|
597
|
+
### ヘキサゴナルアーキテクチャ(ポート&アダプター)
|
|
598
|
+
|
|
599
|
+
生産管理システムは、ヘキサゴナルアーキテクチャ(Ports and Adapters)を採用します。このアーキテクチャにより、ビジネスロジックを外部の技術的関心事から分離し、テスト容易性と保守性を高めます。
|
|
600
|
+
|
|
601
|
+
```plantuml
|
|
602
|
+
@startuml
|
|
603
|
+
!define HEXAGON(name) hexagon name
|
|
604
|
+
|
|
605
|
+
skinparam hexagon {
|
|
606
|
+
BackgroundColor<<domain>> LightBlue
|
|
607
|
+
BackgroundColor<<port>> LightGreen
|
|
608
|
+
BackgroundColor<<adapter>> LightYellow
|
|
609
|
+
}
|
|
610
|
+
|
|
611
|
+
package "生産管理システム" {
|
|
612
|
+
' ドメイン(中心)
|
|
613
|
+
hexagon "ドメイン\n(Domain)" <<domain>> as Domain {
|
|
614
|
+
}
|
|
615
|
+
note bottom of Domain
|
|
616
|
+
エンティティ
|
|
617
|
+
値オブジェクト
|
|
618
|
+
集約
|
|
619
|
+
ドメインサービス
|
|
620
|
+
end note
|
|
621
|
+
|
|
622
|
+
' 入力ポート
|
|
623
|
+
rectangle "入力ポート\n(Input Ports)" <<port>> as InputPort {
|
|
624
|
+
}
|
|
625
|
+
note left of InputPort
|
|
626
|
+
ユースケース
|
|
627
|
+
インターフェース
|
|
628
|
+
end note
|
|
629
|
+
|
|
630
|
+
' 出力ポート
|
|
631
|
+
rectangle "出力ポート\n(Output Ports)" <<port>> as OutputPort {
|
|
632
|
+
}
|
|
633
|
+
note right of OutputPort
|
|
634
|
+
リポジトリ
|
|
635
|
+
インターフェース
|
|
636
|
+
end note
|
|
637
|
+
|
|
638
|
+
' プライマリアダプター
|
|
639
|
+
rectangle "プライマリアダプター\n(Primary Adapters)" <<adapter>> as PrimaryAdapter {
|
|
640
|
+
}
|
|
641
|
+
note top of PrimaryAdapter
|
|
642
|
+
REST API
|
|
643
|
+
GraphQL
|
|
644
|
+
CLI
|
|
645
|
+
end note
|
|
646
|
+
|
|
647
|
+
' セカンダリアダプター
|
|
648
|
+
rectangle "セカンダリアダプター\n(Secondary Adapters)" <<adapter>> as SecondaryAdapter {
|
|
649
|
+
}
|
|
650
|
+
note bottom of SecondaryAdapter
|
|
651
|
+
PostgreSQL
|
|
652
|
+
Redis
|
|
653
|
+
外部 API
|
|
654
|
+
end note
|
|
655
|
+
}
|
|
656
|
+
|
|
657
|
+
PrimaryAdapter --> InputPort
|
|
658
|
+
InputPort --> Domain
|
|
659
|
+
Domain --> OutputPort
|
|
660
|
+
OutputPort --> SecondaryAdapter
|
|
661
|
+
|
|
662
|
+
@enduml
|
|
663
|
+
```
|
|
664
|
+
|
|
665
|
+
#### ドメイン(中心)
|
|
666
|
+
|
|
667
|
+
ドメインはシステムの中心に位置し、ビジネスロジックを実装します。
|
|
668
|
+
|
|
669
|
+
```
|
|
670
|
+
domain/
|
|
671
|
+
├── model/ # ドメインモデル
|
|
672
|
+
│ ├── master/ # マスタ関連
|
|
673
|
+
│ │ ├── Item.java # 品目
|
|
674
|
+
│ │ ├── Bom.java # 部品構成表
|
|
675
|
+
│ │ ├── WorkCalendar.java # カレンダ
|
|
676
|
+
│ │ ├── Location.java # 場所
|
|
677
|
+
│ │ └── Supplier.java # 取引先
|
|
678
|
+
│ ├── planning/ # 計画関連
|
|
679
|
+
│ │ ├── ProductionPlan.java # 生産計画
|
|
680
|
+
│ │ ├── Order.java # オーダ
|
|
681
|
+
│ │ └── Requirement.java # 所要
|
|
682
|
+
│ ├── purchasing/ # 購買関連
|
|
683
|
+
│ │ ├── PurchaseOrder.java # 発注
|
|
684
|
+
│ │ ├── Receiving.java # 入荷受入
|
|
685
|
+
│ │ └── Acceptance.java # 検収
|
|
686
|
+
│ ├── manufacturing/ # 製造関連
|
|
687
|
+
│ │ ├── WorkOrder.java # 作業指示
|
|
688
|
+
│ │ ├── Completion.java # 完成実績
|
|
689
|
+
│ │ └── LaborReport.java # 工数実績
|
|
690
|
+
│ └── inventory/ # 在庫関連
|
|
691
|
+
│ ├── Stock.java # 在庫
|
|
692
|
+
│ └── Issue.java # 払出
|
|
693
|
+
├── type/ # 基本型
|
|
694
|
+
│ ├── Money.java # 通貨
|
|
695
|
+
│ ├── Quantity.java # 数量
|
|
696
|
+
│ └── ItemCode.java # 品目コード
|
|
697
|
+
└── exception/ # ドメイン例外
|
|
698
|
+
└── DomainException.java
|
|
699
|
+
```
|
|
700
|
+
|
|
701
|
+
#### ポート(入力ポート・出力ポート)
|
|
702
|
+
|
|
703
|
+
ポートは、ドメインと外部世界との境界を定義するインターフェースです。
|
|
704
|
+
|
|
705
|
+
| ポート種別 | 役割 | 例 |
|
|
706
|
+
|---|---|---|
|
|
707
|
+
| 入力ポート | 外部からの要求を受け付ける | ユースケースインターフェース |
|
|
708
|
+
| 出力ポート | 外部リソースへのアクセスを抽象化 | リポジトリインターフェース |
|
|
709
|
+
|
|
710
|
+
```java
|
|
711
|
+
// 入力ポート(ユースケースインターフェース)
|
|
712
|
+
public interface ExecuteMrpUseCase {
|
|
713
|
+
MrpResult execute(MrpCommand command);
|
|
714
|
+
}
|
|
715
|
+
|
|
716
|
+
// 出力ポート(リポジトリインターフェース)
|
|
717
|
+
public interface ItemRepository {
|
|
718
|
+
void save(Item item);
|
|
719
|
+
Optional<Item> findByCode(ItemCode code);
|
|
720
|
+
List<Item> findAll();
|
|
721
|
+
}
|
|
722
|
+
```
|
|
723
|
+
|
|
724
|
+
#### アダプター(プライマリ・セカンダリ)
|
|
725
|
+
|
|
726
|
+
アダプターは、ポートの実装を提供し、外部技術とドメインを接続します。
|
|
727
|
+
|
|
728
|
+
| アダプター種別 | 役割 | 例 |
|
|
729
|
+
|---|---|---|
|
|
730
|
+
| プライマリアダプター | 外部からの入力を処理 | REST コントローラ、CLI |
|
|
731
|
+
| セカンダリアダプター | 外部リソースへの出力を処理 | DB リポジトリ実装、外部 API クライアント |
|
|
732
|
+
|
|
733
|
+
```
|
|
734
|
+
infrastructure/
|
|
735
|
+
├── in/ # Input Adapter(プライマリアダプター)
|
|
736
|
+
│ └── rest/ # REST API
|
|
737
|
+
│ ├── controller/
|
|
738
|
+
│ │ ├── ItemController.java
|
|
739
|
+
│ │ ├── BomController.java
|
|
740
|
+
│ │ └── MrpController.java
|
|
741
|
+
│ ├── dto/
|
|
742
|
+
│ │ ├── ItemRequest.java
|
|
743
|
+
│ │ └── ItemResponse.java
|
|
744
|
+
│ └── exception/
|
|
745
|
+
│ └── RestExceptionHandler.java
|
|
746
|
+
├── out/ # Output Adapter(セカンダリアダプター)
|
|
747
|
+
│ └── persistence/ # 永続化
|
|
748
|
+
│ ├── mapper/ # MyBatis Mapper
|
|
749
|
+
│ │ └── ItemMapper.java
|
|
750
|
+
│ ├── repository/ # Repository実装
|
|
751
|
+
│ │ └── ItemRepositoryImpl.java
|
|
752
|
+
│ └── typehandler/ # 型ハンドラ
|
|
753
|
+
│ └── ItemTypeEnumHandler.java
|
|
754
|
+
└── config/ # 設定クラス
|
|
755
|
+
├── DatabaseConfig.java
|
|
756
|
+
└── WebConfig.java
|
|
757
|
+
```
|
|
758
|
+
|
|
759
|
+
#### 依存性の方向と依存性逆転の原則
|
|
760
|
+
|
|
761
|
+
ヘキサゴナルアーキテクチャでは、すべての依存性がドメインに向かいます。
|
|
762
|
+
|
|
763
|
+
```plantuml
|
|
764
|
+
@startuml
|
|
765
|
+
skinparam rectangle {
|
|
766
|
+
BackgroundColor<<domain>> LightBlue
|
|
767
|
+
BackgroundColor<<app>> LightGreen
|
|
768
|
+
BackgroundColor<<infra>> LightYellow
|
|
769
|
+
BackgroundColor<<pres>> LightPink
|
|
770
|
+
}
|
|
771
|
+
|
|
772
|
+
rectangle "Presentation\n(プレゼンテーション層)" <<pres>> as Pres
|
|
773
|
+
rectangle "Application\n(アプリケーション層)" <<app>> as App
|
|
774
|
+
rectangle "Domain\n(ドメイン層)" <<domain>> as Domain
|
|
775
|
+
rectangle "Infrastructure\n(インフラストラクチャ層)" <<infra>> as Infra
|
|
776
|
+
|
|
777
|
+
Pres --> App
|
|
778
|
+
App --> Domain
|
|
779
|
+
Infra --> Domain
|
|
780
|
+
|
|
781
|
+
note right of Domain
|
|
782
|
+
依存性逆転の原則(DIP)
|
|
783
|
+
・ドメインはインターフェースを定義
|
|
784
|
+
・インフラは実装を提供
|
|
785
|
+
・依存の方向は常にドメインへ
|
|
786
|
+
end note
|
|
787
|
+
|
|
788
|
+
@enduml
|
|
789
|
+
```
|
|
790
|
+
|
|
791
|
+
### ドメイン駆動設計の適用
|
|
792
|
+
|
|
793
|
+
#### 集約とリポジトリ
|
|
794
|
+
|
|
795
|
+
生産管理システムの主要な集約を以下に示します。
|
|
796
|
+
|
|
797
|
+
```plantuml
|
|
798
|
+
@startuml
|
|
799
|
+
!define AGGREGATE(name) rectangle name <<aggregate>>
|
|
800
|
+
!define ENTITY(name) class name <<entity>>
|
|
801
|
+
!define VALUE(name) class name <<value>>
|
|
802
|
+
|
|
803
|
+
skinparam class {
|
|
804
|
+
BackgroundColor<<aggregate>> LightBlue
|
|
805
|
+
BackgroundColor<<entity>> LightGreen
|
|
806
|
+
BackgroundColor<<value>> LightYellow
|
|
807
|
+
}
|
|
808
|
+
|
|
809
|
+
package "品目集約" {
|
|
810
|
+
ENTITY(Item) {
|
|
811
|
+
+itemCode: ItemCode
|
|
812
|
+
+itemName: String
|
|
813
|
+
+itemType: ItemType
|
|
814
|
+
+unitCode: String
|
|
815
|
+
+leadTime: Integer
|
|
816
|
+
}
|
|
817
|
+
|
|
818
|
+
VALUE(ItemCode) {
|
|
819
|
+
+value: String
|
|
820
|
+
}
|
|
821
|
+
|
|
822
|
+
VALUE(ItemType) {
|
|
823
|
+
+value: String
|
|
824
|
+
}
|
|
825
|
+
|
|
826
|
+
Item --> ItemCode
|
|
827
|
+
Item --> ItemType
|
|
828
|
+
}
|
|
829
|
+
|
|
830
|
+
package "BOM集約" {
|
|
831
|
+
ENTITY(Bom) {
|
|
832
|
+
+parentItemCode: ItemCode
|
|
833
|
+
+childItemCode: ItemCode
|
|
834
|
+
+requiredQuantity: Quantity
|
|
835
|
+
+effectiveFrom: LocalDate
|
|
836
|
+
+effectiveTo: LocalDate
|
|
837
|
+
}
|
|
838
|
+
|
|
839
|
+
VALUE(Quantity) {
|
|
840
|
+
+value: BigDecimal
|
|
841
|
+
}
|
|
842
|
+
|
|
843
|
+
Bom --> Quantity
|
|
844
|
+
}
|
|
845
|
+
|
|
846
|
+
@enduml
|
|
847
|
+
```
|
|
848
|
+
|
|
849
|
+
| 集約 | ルートエンティティ | 主な責務 |
|
|
850
|
+
|---|---|---|
|
|
851
|
+
| 品目集約 | Item | 品目情報の管理 |
|
|
852
|
+
| BOM 集約 | Bom | 部品構成の管理 |
|
|
853
|
+
| オーダ集約 | Order | 生産・購買オーダの管理 |
|
|
854
|
+
| 作業指示集約 | WorkOrder | 製造指示の管理 |
|
|
855
|
+
| 在庫集約 | Stock | 在庫数量の管理 |
|
|
856
|
+
|
|
857
|
+
#### ドメインサービス
|
|
858
|
+
|
|
859
|
+
複数の集約をまたぐビジネスロジックは、ドメインサービスとして実装します。
|
|
860
|
+
|
|
861
|
+
```java
|
|
862
|
+
// MRP ドメインサービス
|
|
863
|
+
public class MrpDomainService {
|
|
864
|
+
|
|
865
|
+
public List<Requirement> explodeRequirements(
|
|
866
|
+
Item item,
|
|
867
|
+
Quantity requiredQty,
|
|
868
|
+
LocalDate requiredDate,
|
|
869
|
+
BomRepository bomRepository) {
|
|
870
|
+
|
|
871
|
+
List<Bom> children = bomRepository.findChildren(item.getItemCode());
|
|
872
|
+
|
|
873
|
+
return children.stream()
|
|
874
|
+
.map(bom -> new Requirement(
|
|
875
|
+
bom.getChildItemCode(),
|
|
876
|
+
requiredQty.multiply(bom.getRequiredQuantity()),
|
|
877
|
+
requiredDate.minusDays(item.getLeadTime())
|
|
878
|
+
))
|
|
879
|
+
.collect(Collectors.toList());
|
|
880
|
+
}
|
|
881
|
+
}
|
|
882
|
+
```
|
|
883
|
+
|
|
884
|
+
#### アプリケーションサービス
|
|
885
|
+
|
|
886
|
+
ユースケースの実装は、アプリケーションサービスとして実装します。
|
|
887
|
+
|
|
888
|
+
```java
|
|
889
|
+
@Service
|
|
890
|
+
@RequiredArgsConstructor
|
|
891
|
+
public class MrpApplicationService implements ExecuteMrpUseCase {
|
|
892
|
+
|
|
893
|
+
private final ItemRepository itemRepository;
|
|
894
|
+
private final BomRepository bomRepository;
|
|
895
|
+
private final OrderRepository orderRepository;
|
|
896
|
+
private final MrpDomainService mrpDomainService;
|
|
897
|
+
|
|
898
|
+
@Override
|
|
899
|
+
@Transactional
|
|
900
|
+
public MrpResult execute(MrpCommand command) {
|
|
901
|
+
// 1. 対象品目の取得
|
|
902
|
+
Item item = itemRepository.findByCode(command.getItemCode())
|
|
903
|
+
.orElseThrow(() -> new ItemNotFoundException(command.getItemCode()));
|
|
904
|
+
|
|
905
|
+
// 2. 所要量展開
|
|
906
|
+
List<Requirement> requirements = mrpDomainService.explodeRequirements(
|
|
907
|
+
item, command.getQuantity(), command.getRequiredDate(), bomRepository);
|
|
908
|
+
|
|
909
|
+
// 3. オーダ生成
|
|
910
|
+
List<Order> orders = requirements.stream()
|
|
911
|
+
.map(this::createOrder)
|
|
912
|
+
.collect(Collectors.toList());
|
|
913
|
+
|
|
914
|
+
orders.forEach(orderRepository::save);
|
|
915
|
+
|
|
916
|
+
return new MrpResult(orders);
|
|
917
|
+
}
|
|
918
|
+
}
|
|
919
|
+
```
|
|
920
|
+
|
|
921
|
+
### API 設計
|
|
922
|
+
|
|
923
|
+
#### RESTful API の基本方針
|
|
924
|
+
|
|
925
|
+
| 方針 | 説明 |
|
|
926
|
+
|---|---|
|
|
927
|
+
| リソース指向 | URL はリソースを表現(動詞ではなく名詞) |
|
|
928
|
+
| HTTP メソッド | GET(取得)、POST(作成)、PUT(更新)、DELETE(削除) |
|
|
929
|
+
| ステータスコード | 200(成功)、201(作成)、400(クライアントエラー)、404(未検出)、500(サーバーエラー) |
|
|
930
|
+
|
|
931
|
+
#### エンドポイント設計
|
|
932
|
+
|
|
933
|
+
| エンドポイント | メソッド | 説明 |
|
|
934
|
+
|---|---|---|
|
|
935
|
+
| `/api/items` | GET | 品目一覧取得 |
|
|
936
|
+
| `/api/items/{code}` | GET | 品目詳細取得 |
|
|
937
|
+
| `/api/items` | POST | 品目登録 |
|
|
938
|
+
| `/api/items/{code}` | PUT | 品目更新 |
|
|
939
|
+
| `/api/bom/{parentCode}` | GET | BOM 展開(子品目一覧) |
|
|
940
|
+
| `/api/mrp/execute` | POST | MRP 実行 |
|
|
941
|
+
| `/api/orders` | GET | オーダ一覧取得 |
|
|
942
|
+
| `/api/orders/{id}` | GET | オーダ詳細取得 |
|
|
943
|
+
| `/api/work-orders` | GET | 作業指示一覧取得 |
|
|
944
|
+
| `/api/stock/{locationCode}/{itemCode}` | GET | 在庫照会 |
|
|
945
|
+
|
|
946
|
+
---
|
|
947
|
+
|
|
948
|
+
## まとめ
|
|
949
|
+
|
|
950
|
+
本章では、生産管理システムの全体像について解説しました。
|
|
951
|
+
|
|
952
|
+
1. **生産管理システムのスコープ**
|
|
953
|
+
- 生産計画(MPS・MRP)、購買管理、工程管理、在庫管理、品質管理、原価管理
|
|
954
|
+
- マスタ情報とトランザクション情報の分類
|
|
955
|
+
|
|
956
|
+
2. **生産組織の役割分担**
|
|
957
|
+
- 営業部・生産管理部・製造部・購買部・外注部・資材倉庫・製品倉庫
|
|
958
|
+
- 各部門の責務と連携ポイント
|
|
959
|
+
|
|
960
|
+
3. **生産管理システムのアーキテクチャ**
|
|
961
|
+
- ヘキサゴナルアーキテクチャ(ポート&アダプター)
|
|
962
|
+
- ドメイン駆動設計の適用
|
|
963
|
+
- RESTful API の設計方針
|
|
964
|
+
|
|
965
|
+
次章では、品目マスタや BOM(部品構成表)などのマスタ情報の設計について詳しく解説します。
|