@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.
Files changed (66) hide show
  1. package/lib/assets/docs/article/index.md +4 -1
  2. package/lib/assets/docs/article/practical-database-design/index.md +121 -0
  3. package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -0
  4. package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -0
  5. package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -0
  6. package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -0
  7. package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -0
  8. package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -0
  9. package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -0
  10. package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -0
  11. package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -0
  12. package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -0
  13. package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -0
  14. package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -0
  15. package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -0
  16. package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -0
  17. package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -0
  18. package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -0
  19. package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -0
  20. package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -0
  21. package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -0
  22. package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -0
  23. package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -0
  24. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -0
  25. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -0
  26. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -0
  27. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -0
  28. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -0
  29. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -0
  30. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -0
  31. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -0
  32. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -0
  33. package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -0
  34. package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -0
  35. package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -0
  36. package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -0
  37. package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -0
  38. package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -0
  39. package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -0
  40. package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -0
  41. package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -0
  42. package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -0
  43. package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -0
  44. package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -0
  45. package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -0
  46. package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -0
  47. package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -0
  48. package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -0
  49. package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -0
  50. package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -0
  51. package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -0
  52. package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -0
  53. package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -0
  54. package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -0
  55. package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -0
  56. package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -0
  57. package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -0
  58. package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -0
  59. package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -0
  60. package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -0
  61. package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -0
  62. package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -0
  63. package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -0
  64. package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -0
  65. package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -0
  66. 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(部品構成表)などのマスタ情報の設計について詳しく解説します。