@k2works/claude-code-booster 3.2.1 → 3.3.1
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/.claude/skills/analyzing-business/SKILL.md +2 -2
- package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +5 -5
- package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +2 -2
- package/lib/assets/.claude/skills/generating-slides/SKILL.md +7 -7
- 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,667 @@
|
|
|
1
|
+
# 第14章:財務会計システムの全体像
|
|
2
|
+
|
|
3
|
+
本章では、財務会計システムの全体像を把握し、販売管理システムとの連携や、財務会計と管理会計の違い、システムアーキテクチャについて解説します。
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## 14.1 財務会計システムのスコープ
|
|
8
|
+
|
|
9
|
+
### 基幹業務システムにおける位置づけ
|
|
10
|
+
|
|
11
|
+
財務会計システムは、基幹業務システムの中で他のシステムから仕訳データを受け取り、企業の財務状態を管理する重要なシステムです。
|
|
12
|
+
|
|
13
|
+
```plantuml
|
|
14
|
+
@startuml
|
|
15
|
+
|
|
16
|
+
title 基幹業務システムの全体像
|
|
17
|
+
|
|
18
|
+
state "得意先\n(Customer)" as Customer
|
|
19
|
+
state "販売管理\n(Sales Management)" as SalesManagement
|
|
20
|
+
SalesManagement : ・受注 \n・出荷 \n・売上
|
|
21
|
+
|
|
22
|
+
state "購買管理\n(Procurement Management)" as ProcurementManagement
|
|
23
|
+
ProcurementManagement : ・発注\n・入荷/受入\n・仕入(検収)
|
|
24
|
+
|
|
25
|
+
state "在庫\n(Inventory)" as Inventory
|
|
26
|
+
|
|
27
|
+
state "仕入先\n(Supplier)" as Supplier
|
|
28
|
+
|
|
29
|
+
state "生産管理\n(Production Management)" as ProductionManagement
|
|
30
|
+
ProductionManagement : ・生産計画\n・品質管理\n・工程管理\n・製造原価管理
|
|
31
|
+
|
|
32
|
+
state "債権管理\n(Accounts Receivable)" as AccountsReceivable
|
|
33
|
+
AccountsReceivable : ・請求 \n・入金
|
|
34
|
+
|
|
35
|
+
state "債務管理\n(Accounts Payable)" as AccountsPayable
|
|
36
|
+
AccountsPayable : ・支払\n・出金
|
|
37
|
+
|
|
38
|
+
state "財務会計\n(Financial Accounting)" as Accounting #LightBlue
|
|
39
|
+
Accounting : ・勘定科目管理\n・仕訳処理\n・残高管理\n・財務諸表\n・決算処理
|
|
40
|
+
|
|
41
|
+
[*] -> Customer
|
|
42
|
+
|
|
43
|
+
Customer --> SalesManagement
|
|
44
|
+
SalesManagement --> AccountsReceivable
|
|
45
|
+
SalesManagement --> ProcurementManagement : 調達依頼
|
|
46
|
+
SalesManagement --> ProductionManagement : 需要予測 \n製造指示
|
|
47
|
+
SalesManagement --> Accounting : 仕訳
|
|
48
|
+
SalesManagement --> Customer
|
|
49
|
+
Inventory --> SalesManagement
|
|
50
|
+
|
|
51
|
+
ProcurementManagement --> Inventory
|
|
52
|
+
ProcurementManagement --> AccountsPayable
|
|
53
|
+
ProcurementManagement --> Supplier
|
|
54
|
+
Supplier --> ProcurementManagement
|
|
55
|
+
ProductionManagement --> ProcurementManagement : 調達依頼
|
|
56
|
+
|
|
57
|
+
ProductionManagement --> Inventory : 入荷
|
|
58
|
+
Inventory --> ProductionManagement : 払出
|
|
59
|
+
|
|
60
|
+
AccountsReceivable --> Accounting
|
|
61
|
+
AccountsPayable --> Accounting
|
|
62
|
+
ProductionManagement --> Accounting : 仕訳
|
|
63
|
+
ProcurementManagement --> Accounting : 仕訳
|
|
64
|
+
|
|
65
|
+
Customer -> [*]
|
|
66
|
+
|
|
67
|
+
@enduml
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### 財務会計システムの業務領域
|
|
71
|
+
|
|
72
|
+
財務会計システムは、以下の業務領域をカバーします。
|
|
73
|
+
|
|
74
|
+
```plantuml
|
|
75
|
+
@startuml
|
|
76
|
+
|
|
77
|
+
[*] -> 販売管理
|
|
78
|
+
販売管理 --> 財務会計 : 売上仕訳
|
|
79
|
+
販売管理 : 売掛金 / 売上
|
|
80
|
+
|
|
81
|
+
[*] -> 購買管理
|
|
82
|
+
購買管理 --> 財務会計 : 仕入仕訳
|
|
83
|
+
購買管理 : 仕入 / 買掛金
|
|
84
|
+
|
|
85
|
+
[*] -> 債権管理
|
|
86
|
+
債権管理 --> 財務会計 : 入金仕訳
|
|
87
|
+
債権管理 : 現金預金 / 売掛金
|
|
88
|
+
|
|
89
|
+
[*] -> 債務管理
|
|
90
|
+
債務管理 --> 財務会計 : 支払仕訳
|
|
91
|
+
債務管理 : 買掛金 / 現金預金
|
|
92
|
+
|
|
93
|
+
財務会計 --> 帳票出力
|
|
94
|
+
財務会計 : 勘定科目管理 \n仕訳処理 \n残高管理
|
|
95
|
+
帳票出力 : 日計表 \n合計残高試算表 \n財務諸表
|
|
96
|
+
|
|
97
|
+
帳票出力 -> [*]
|
|
98
|
+
|
|
99
|
+
@enduml
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
### 業務機能の概要
|
|
103
|
+
|
|
104
|
+
| 業務 | 説明 |
|
|
105
|
+
|------|------|
|
|
106
|
+
| **債権管理(請求・入金)** | 売上に基づく請求書発行と入金消込処理 |
|
|
107
|
+
| **債務管理(支払・出金)** | 仕入に基づく支払処理と出金管理 |
|
|
108
|
+
| **経理(仕訳・決算)** | 仕訳入力・自動仕訳・残高管理・決算処理 |
|
|
109
|
+
|
|
110
|
+
### ユースケース図
|
|
111
|
+
|
|
112
|
+
財務会計システム全体のユースケースは以下の通りです。
|
|
113
|
+
|
|
114
|
+
```plantuml
|
|
115
|
+
@startuml
|
|
116
|
+
left to right direction
|
|
117
|
+
skinparam packageStyle rectangle
|
|
118
|
+
skinparam linetype ortho
|
|
119
|
+
title 財務会計システム ユースケース図
|
|
120
|
+
|
|
121
|
+
actor 経理担当者 as accounting
|
|
122
|
+
actor 財務担当者 as finance
|
|
123
|
+
actor 営業担当者 as sales
|
|
124
|
+
actor 購買担当者 as buyer
|
|
125
|
+
actor 管理者 as admin
|
|
126
|
+
|
|
127
|
+
rectangle 財務会計システム {
|
|
128
|
+
usecase "勘定科目管理" as UC_ACCOUNT
|
|
129
|
+
usecase "仕訳入力" as UC_JOURNAL
|
|
130
|
+
usecase "自動仕訳" as UC_AUTO_JOURNAL
|
|
131
|
+
usecase "残高照会" as UC_BALANCE
|
|
132
|
+
usecase "日計表出力" as UC_DAILY
|
|
133
|
+
usecase "試算表出力" as UC_TRIAL
|
|
134
|
+
usecase "財務諸表出力" as UC_FINANCIAL
|
|
135
|
+
usecase "決算処理" as UC_CLOSING
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
admin -- UC_ACCOUNT
|
|
139
|
+
accounting -- UC_JOURNAL
|
|
140
|
+
accounting -- UC_BALANCE
|
|
141
|
+
accounting -- UC_DAILY
|
|
142
|
+
accounting -- UC_TRIAL
|
|
143
|
+
accounting -- UC_CLOSING
|
|
144
|
+
finance -- UC_FINANCIAL
|
|
145
|
+
sales -- UC_AUTO_JOURNAL
|
|
146
|
+
buyer -- UC_AUTO_JOURNAL
|
|
147
|
+
@enduml
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
### 会計組織の役割分担
|
|
151
|
+
|
|
152
|
+
| 部門 | 役割 | 主な業務 |
|
|
153
|
+
|------|------|----------|
|
|
154
|
+
| **経理部門** | 日常の会計処理 | 仕訳入力、残高照会、日計表出力 |
|
|
155
|
+
| **財務部門** | 財務諸表の作成 | 試算表出力、財務諸表作成、決算処理 |
|
|
156
|
+
| **営業部門** | 売上データの提供 | 売上仕訳の元データ作成 |
|
|
157
|
+
| **購買部門** | 仕入データの提供 | 仕入仕訳の元データ作成 |
|
|
158
|
+
| **管理者** | マスタ管理 | 勘定科目マスタの管理 |
|
|
159
|
+
|
|
160
|
+
---
|
|
161
|
+
|
|
162
|
+
## 14.2 財務会計と管理会計の違い
|
|
163
|
+
|
|
164
|
+
### 財務会計:外部報告目的
|
|
165
|
+
|
|
166
|
+
財務会計は、株主・債権者・税務署などの外部利害関係者に対して、企業の財政状態や経営成績を報告することを目的とします。
|
|
167
|
+
|
|
168
|
+
```plantuml
|
|
169
|
+
@startuml
|
|
170
|
+
title 財務会計の目的と特徴
|
|
171
|
+
|
|
172
|
+
package "財務会計" {
|
|
173
|
+
rectangle "貸借対照表\n(B/S)" as BS
|
|
174
|
+
rectangle "損益計算書\n(P/L)" as PL
|
|
175
|
+
rectangle "キャッシュフロー計算書\n(C/F)" as CF
|
|
176
|
+
rectangle "株主資本等変動計算書" as SE
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
actor "株主" as shareholder
|
|
180
|
+
actor "債権者" as creditor
|
|
181
|
+
actor "税務署" as tax
|
|
182
|
+
actor "監査法人" as auditor
|
|
183
|
+
|
|
184
|
+
BS --> shareholder
|
|
185
|
+
BS --> creditor
|
|
186
|
+
PL --> shareholder
|
|
187
|
+
PL --> tax
|
|
188
|
+
CF --> creditor
|
|
189
|
+
CF --> auditor
|
|
190
|
+
SE --> shareholder
|
|
191
|
+
|
|
192
|
+
note right of BS
|
|
193
|
+
財政状態の報告
|
|
194
|
+
(資産・負債・純資産)
|
|
195
|
+
end note
|
|
196
|
+
|
|
197
|
+
note right of PL
|
|
198
|
+
経営成績の報告
|
|
199
|
+
(収益・費用・利益)
|
|
200
|
+
end note
|
|
201
|
+
@enduml
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
**財務会計の特徴**
|
|
205
|
+
|
|
206
|
+
| 項目 | 内容 |
|
|
207
|
+
|------|------|
|
|
208
|
+
| 目的 | 外部への報告(法定開示) |
|
|
209
|
+
| 対象 | 株主、債権者、税務署 |
|
|
210
|
+
| 規則 | 会計基準、税法に準拠 |
|
|
211
|
+
| 期間 | 会計期間(通常1年) |
|
|
212
|
+
| 形式 | 財務諸表(B/S, P/L, C/F) |
|
|
213
|
+
|
|
214
|
+
### 管理会計:内部意思決定目的
|
|
215
|
+
|
|
216
|
+
管理会計は、経営者や管理者が意思決定を行うための情報を提供することを目的とします。
|
|
217
|
+
|
|
218
|
+
```plantuml
|
|
219
|
+
@startuml
|
|
220
|
+
title 管理会計の目的と特徴
|
|
221
|
+
|
|
222
|
+
package "管理会計" {
|
|
223
|
+
rectangle "予算管理" as budget
|
|
224
|
+
rectangle "原価計算" as cost
|
|
225
|
+
rectangle "業績評価" as performance
|
|
226
|
+
rectangle "経営分析" as analysis
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
actor "経営者" as ceo
|
|
230
|
+
actor "部門長" as manager
|
|
231
|
+
actor "プロジェクトリーダー" as leader
|
|
232
|
+
|
|
233
|
+
budget --> ceo
|
|
234
|
+
budget --> manager
|
|
235
|
+
cost --> manager
|
|
236
|
+
cost --> leader
|
|
237
|
+
performance --> ceo
|
|
238
|
+
performance --> manager
|
|
239
|
+
analysis --> ceo
|
|
240
|
+
|
|
241
|
+
note right of budget
|
|
242
|
+
計画と実績の比較
|
|
243
|
+
予実差異分析
|
|
244
|
+
end note
|
|
245
|
+
|
|
246
|
+
note right of cost
|
|
247
|
+
製品別・部門別原価
|
|
248
|
+
標準原価・実際原価
|
|
249
|
+
end note
|
|
250
|
+
|
|
251
|
+
note right of analysis
|
|
252
|
+
収益性分析
|
|
253
|
+
安全性分析
|
|
254
|
+
効率性分析
|
|
255
|
+
end note
|
|
256
|
+
@enduml
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
**管理会計の特徴**
|
|
260
|
+
|
|
261
|
+
| 項目 | 内容 |
|
|
262
|
+
|------|------|
|
|
263
|
+
| 目的 | 内部の意思決定支援 |
|
|
264
|
+
| 対象 | 経営者、管理者 |
|
|
265
|
+
| 規則 | 自由(社内ルール) |
|
|
266
|
+
| 期間 | 任意(月次、週次、日次) |
|
|
267
|
+
| 形式 | 自由(セグメント別、製品別など) |
|
|
268
|
+
|
|
269
|
+
### 財務会計と管理会計の比較
|
|
270
|
+
|
|
271
|
+
```plantuml
|
|
272
|
+
@startuml
|
|
273
|
+
title 財務会計と管理会計の比較
|
|
274
|
+
|
|
275
|
+
rectangle "財務会計" as FA #LightBlue {
|
|
276
|
+
(外部報告)
|
|
277
|
+
(法定開示)
|
|
278
|
+
(過去指向)
|
|
279
|
+
(会計基準準拠)
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
rectangle "管理会計" as MA #LightGreen {
|
|
283
|
+
(内部報告)
|
|
284
|
+
(任意開示)
|
|
285
|
+
(将来指向)
|
|
286
|
+
(自由形式)
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
FA -[hidden]right- MA
|
|
290
|
+
|
|
291
|
+
note bottom of FA
|
|
292
|
+
<b>共通の基盤</b>
|
|
293
|
+
・仕訳データ
|
|
294
|
+
・勘定科目体系
|
|
295
|
+
・残高情報
|
|
296
|
+
end note
|
|
297
|
+
@enduml
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
| 比較項目 | 財務会計 | 管理会計 |
|
|
301
|
+
|----------|----------|----------|
|
|
302
|
+
| 利用者 | 外部利害関係者 | 経営者・管理者 |
|
|
303
|
+
| 目的 | 報告義務の履行 | 意思決定の支援 |
|
|
304
|
+
| 規制 | 会計基準・税法 | なし(任意) |
|
|
305
|
+
| 時間軸 | 過去(実績) | 過去・現在・将来 |
|
|
306
|
+
| 詳細度 | 法定様式 | 必要に応じて詳細 |
|
|
307
|
+
| 更新頻度 | 期末(四半期・年次) | 随時(日次・週次) |
|
|
308
|
+
|
|
309
|
+
---
|
|
310
|
+
|
|
311
|
+
## 14.3 財務会計システムのアーキテクチャ
|
|
312
|
+
|
|
313
|
+
### 技術スタックと環境設定
|
|
314
|
+
|
|
315
|
+
財務会計システム(FAS)は、販売管理システム(SMS)と同じ技術スタックを使用しますが、独立した環境で動作します。
|
|
316
|
+
|
|
317
|
+
| 項目 | 財務会計システム (FAS) | 販売管理システム (SMS) |
|
|
318
|
+
|------|------------------------|------------------------|
|
|
319
|
+
| アプリケーションポート | 8081 | 8080 |
|
|
320
|
+
| PostgreSQL ポート | 5433 | 5432 |
|
|
321
|
+
| データベース名 | fas | sms |
|
|
322
|
+
| Java バージョン | 25 | 25 |
|
|
323
|
+
| Spring Boot | 4.0.0 | 4.0.0 |
|
|
324
|
+
| MyBatis | 4.0.0 | 4.0.0 |
|
|
325
|
+
|
|
326
|
+
### プロジェクト構成
|
|
327
|
+
|
|
328
|
+
財務会計システムは、ヘキサゴナルアーキテクチャ(ポート&アダプターパターン)を採用します。
|
|
329
|
+
|
|
330
|
+
```
|
|
331
|
+
apps/fas/
|
|
332
|
+
├── backend/
|
|
333
|
+
│ ├── src/main/java/com/example/fas/
|
|
334
|
+
│ │ ├── domain/ # ドメイン層(純粋なビジネスロジック)
|
|
335
|
+
│ │ │ ├── model/ # ドメインモデル(エンティティ、値オブジェクト)
|
|
336
|
+
│ │ │ │ ├── account/ # 勘定科目関連
|
|
337
|
+
│ │ │ │ ├── journal/ # 仕訳関連
|
|
338
|
+
│ │ │ │ └── balance/ # 残高関連
|
|
339
|
+
│ │ │ ├── type/ # 基本型(通貨、金額等)
|
|
340
|
+
│ │ │ └── exception/ # ドメイン例外
|
|
341
|
+
│ │ │
|
|
342
|
+
│ │ ├── application/ # アプリケーション層
|
|
343
|
+
│ │ │ └── port/
|
|
344
|
+
│ │ │ └── out/ # Output Port(リポジトリインターフェース)
|
|
345
|
+
│ │ │
|
|
346
|
+
│ │ └── infrastructure/ # インフラストラクチャ層
|
|
347
|
+
│ │ ├── config/ # 設定クラス
|
|
348
|
+
│ │ ├── in/ # Input Adapter(受信アダプター)
|
|
349
|
+
│ │ │ ├── rest/ # REST API(Web実装)
|
|
350
|
+
│ │ │ │ ├── controller/ # REST Controller
|
|
351
|
+
│ │ │ │ ├── dto/ # Data Transfer Object
|
|
352
|
+
│ │ │ │ └── exception/ # Exception Handler
|
|
353
|
+
│ │ │ └── seed/ # Seed データ投入
|
|
354
|
+
│ │ └── out/ # Output Adapter(送信アダプター)
|
|
355
|
+
│ │ └── persistence/ # DB実装
|
|
356
|
+
│ │ ├── mapper/ # MyBatis Mapper
|
|
357
|
+
│ │ ├── repository/ # Repository実装
|
|
358
|
+
│ │ └── typehandler/ # 型ハンドラー
|
|
359
|
+
│ │
|
|
360
|
+
│ ├── src/main/resources/
|
|
361
|
+
│ │ ├── application.yml # アプリケーション設定
|
|
362
|
+
│ │ └── db/migration/ # Flyway マイグレーション
|
|
363
|
+
│ │ └── V001__create_enum_types.sql
|
|
364
|
+
│ │
|
|
365
|
+
│ ├── src/test/java/com/example/fas/
|
|
366
|
+
│ │ └── testsetup/
|
|
367
|
+
│ │ └── BaseIntegrationTest.java # 統合テスト基底クラス
|
|
368
|
+
│ │
|
|
369
|
+
│ └── config/ # 品質ツール設定
|
|
370
|
+
│ ├── checkstyle/
|
|
371
|
+
│ ├── pmd/
|
|
372
|
+
│ └── spotbugs/
|
|
373
|
+
│
|
|
374
|
+
└── docker-compose.yml # PostgreSQL コンテナ定義
|
|
375
|
+
```
|
|
376
|
+
|
|
377
|
+
### ヘキサゴナルアーキテクチャ(ポート&アダプター)
|
|
378
|
+
|
|
379
|
+
```plantuml
|
|
380
|
+
@startuml hexagonal_architecture_accounting
|
|
381
|
+
!define RECTANGLE class
|
|
382
|
+
|
|
383
|
+
package "Hexagonal Architecture (財務会計API)" {
|
|
384
|
+
|
|
385
|
+
RECTANGLE "Application Core\n(Domain + Use Cases)" as core {
|
|
386
|
+
- Account (勘定科目)
|
|
387
|
+
- Journal (仕訳)
|
|
388
|
+
- JournalEntry (仕訳明細)
|
|
389
|
+
- DailyBalance (日次残高)
|
|
390
|
+
- MonthlyBalance (月次残高)
|
|
391
|
+
- AccountUseCase
|
|
392
|
+
- JournalUseCase
|
|
393
|
+
- BalanceUseCase
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
RECTANGLE "Input Adapters\n(Driving Side)" as input {
|
|
397
|
+
- Spring Controllers
|
|
398
|
+
- REST API Endpoints
|
|
399
|
+
- Request Validation
|
|
400
|
+
- Error Handling
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
RECTANGLE "Output Adapters\n(Driven Side)" as output {
|
|
404
|
+
- MyBatis Repository
|
|
405
|
+
- Database Access
|
|
406
|
+
- Entity Mapping
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
input --> core : "Input Ports\n(Use Cases)"
|
|
411
|
+
core --> output : "Output Ports\n(Repository Interfaces)"
|
|
412
|
+
|
|
413
|
+
note top of core
|
|
414
|
+
純粋なビジネスロジック
|
|
415
|
+
MyBatis に依存しない
|
|
416
|
+
高速でテスト可能
|
|
417
|
+
end note
|
|
418
|
+
|
|
419
|
+
note left of input
|
|
420
|
+
外部からアプリケーションを
|
|
421
|
+
駆動するアダプター
|
|
422
|
+
HTTP, REST等
|
|
423
|
+
end note
|
|
424
|
+
|
|
425
|
+
note right of output
|
|
426
|
+
アプリケーションが外部の
|
|
427
|
+
技術を使うためのアダプター
|
|
428
|
+
PostgreSQL, MyBatis等
|
|
429
|
+
end note
|
|
430
|
+
@enduml
|
|
431
|
+
```
|
|
432
|
+
|
|
433
|
+
### アーキテクチャの特徴
|
|
434
|
+
|
|
435
|
+
| 特徴 | 説明 |
|
|
436
|
+
|------|------|
|
|
437
|
+
| **ドメイン中心** | ビジネスロジックを中心に据え、外部技術から分離 |
|
|
438
|
+
| **依存性の逆転** | ドメイン層は外部に依存せず、外部がドメイン層に依存 |
|
|
439
|
+
| **テスト容易性** | モックやスタブを使った単体テストが容易 |
|
|
440
|
+
| **技術変更の容易さ** | アダプターを差し替えるだけで技術を変更可能 |
|
|
441
|
+
|
|
442
|
+
### ドメイン駆動設計の適用
|
|
443
|
+
|
|
444
|
+
#### 集約とリポジトリ
|
|
445
|
+
|
|
446
|
+
```plantuml
|
|
447
|
+
@startuml
|
|
448
|
+
title 財務会計システムの集約
|
|
449
|
+
|
|
450
|
+
package "勘定科目集約" {
|
|
451
|
+
class Account <<Aggregate Root>> {
|
|
452
|
+
accountCode: String
|
|
453
|
+
accountName: String
|
|
454
|
+
bsPlType: BsPlType
|
|
455
|
+
debitCreditType: DebitCreditType
|
|
456
|
+
}
|
|
457
|
+
class AccountStructure {
|
|
458
|
+
accountCode: String
|
|
459
|
+
parentAccountCode: String
|
|
460
|
+
accountPath: String
|
|
461
|
+
}
|
|
462
|
+
Account "1" *-- "*" AccountStructure
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
package "仕訳集約" {
|
|
466
|
+
class Journal <<Aggregate Root>> {
|
|
467
|
+
journalNumber: String
|
|
468
|
+
journalDate: LocalDate
|
|
469
|
+
journalType: JournalType
|
|
470
|
+
}
|
|
471
|
+
class JournalDetail {
|
|
472
|
+
lineNumber: Integer
|
|
473
|
+
lineSummary: String
|
|
474
|
+
}
|
|
475
|
+
class JournalEntry {
|
|
476
|
+
debitCreditType: DebitCreditType
|
|
477
|
+
accountCode: String
|
|
478
|
+
amount: BigDecimal
|
|
479
|
+
}
|
|
480
|
+
Journal "1" *-- "*" JournalDetail
|
|
481
|
+
JournalDetail "1" *-- "*" JournalEntry
|
|
482
|
+
}
|
|
483
|
+
|
|
484
|
+
package "残高集約" {
|
|
485
|
+
class DailyBalance <<Aggregate Root>> {
|
|
486
|
+
accountCode: String
|
|
487
|
+
balanceDate: LocalDate
|
|
488
|
+
debitAmount: BigDecimal
|
|
489
|
+
creditAmount: BigDecimal
|
|
490
|
+
}
|
|
491
|
+
class MonthlyBalance <<Aggregate Root>> {
|
|
492
|
+
accountCode: String
|
|
493
|
+
fiscalYear: Integer
|
|
494
|
+
fiscalMonth: Integer
|
|
495
|
+
openingBalance: BigDecimal
|
|
496
|
+
closingBalance: BigDecimal
|
|
497
|
+
}
|
|
498
|
+
}
|
|
499
|
+
|
|
500
|
+
@enduml
|
|
501
|
+
```
|
|
502
|
+
|
|
503
|
+
#### ドメインサービス
|
|
504
|
+
|
|
505
|
+
| サービス | 責務 |
|
|
506
|
+
|----------|------|
|
|
507
|
+
| **JournalValidationService** | 仕訳の貸借一致検証 |
|
|
508
|
+
| **BalanceCalculationService** | 残高計算・集計 |
|
|
509
|
+
| **AutoJournalService** | 自動仕訳生成 |
|
|
510
|
+
| **ClosingService** | 月次・年次決算処理 |
|
|
511
|
+
|
|
512
|
+
#### アプリケーションサービス
|
|
513
|
+
|
|
514
|
+
| サービス | 責務 |
|
|
515
|
+
|----------|------|
|
|
516
|
+
| **AccountUseCase** | 勘定科目の登録・照会・更新 |
|
|
517
|
+
| **JournalUseCase** | 仕訳の登録・照会・更新 |
|
|
518
|
+
| **BalanceUseCase** | 残高照会・帳票出力 |
|
|
519
|
+
| **ClosingUseCase** | 決算処理の実行 |
|
|
520
|
+
|
|
521
|
+
### API 設計
|
|
522
|
+
|
|
523
|
+
#### RESTful API の基本方針
|
|
524
|
+
|
|
525
|
+
| 方針 | 説明 |
|
|
526
|
+
|------|------|
|
|
527
|
+
| リソース指向 | 勘定科目、仕訳、残高をリソースとして設計 |
|
|
528
|
+
| HTTP メソッド | GET(照会)、POST(登録)、PUT(更新)、DELETE(削除) |
|
|
529
|
+
| ステータスコード | 200(成功)、201(作成)、400(バリデーションエラー)、404(未検出)、409(競合) |
|
|
530
|
+
| エラーレスポンス | ProblemDetail 形式(RFC 7807) |
|
|
531
|
+
|
|
532
|
+
#### エンドポイント設計
|
|
533
|
+
|
|
534
|
+
| メソッド | パス | 説明 |
|
|
535
|
+
|----------|------|------|
|
|
536
|
+
| GET | `/api/v1/accounts` | 勘定科目一覧の取得 |
|
|
537
|
+
| GET | `/api/v1/accounts/{code}` | 勘定科目の取得 |
|
|
538
|
+
| POST | `/api/v1/accounts` | 勘定科目の登録 |
|
|
539
|
+
| PUT | `/api/v1/accounts/{code}` | 勘定科目の更新 |
|
|
540
|
+
| DELETE | `/api/v1/accounts/{code}` | 勘定科目の削除 |
|
|
541
|
+
| GET | `/api/v1/journals` | 仕訳一覧の取得 |
|
|
542
|
+
| POST | `/api/v1/journals` | 仕訳の登録 |
|
|
543
|
+
| GET | `/api/v1/balances/daily` | 日次残高の取得 |
|
|
544
|
+
| GET | `/api/v1/balances/monthly` | 月次残高の取得 |
|
|
545
|
+
| GET | `/api/v1/reports/trial-balance` | 試算表の出力 |
|
|
546
|
+
|
|
547
|
+
### マスタ情報とトランザクション情報
|
|
548
|
+
|
|
549
|
+
財務会計システムのデータは、大きく「マスタ情報」と「トランザクション情報」に分類されます。
|
|
550
|
+
|
|
551
|
+
```plantuml
|
|
552
|
+
@startuml
|
|
553
|
+
title 財務会計システム ER図(概要)
|
|
554
|
+
|
|
555
|
+
' マスタ系
|
|
556
|
+
package "マスタ情報" {
|
|
557
|
+
entity 勘定科目マスタ
|
|
558
|
+
entity 勘定科目構成マスタ
|
|
559
|
+
entity 課税取引マスタ
|
|
560
|
+
entity 部門マスタ
|
|
561
|
+
entity 通貨マスタ
|
|
562
|
+
entity 為替レートマスタ
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
' 仕訳系
|
|
566
|
+
package "仕訳情報" {
|
|
567
|
+
entity 仕訳データ
|
|
568
|
+
entity 仕訳明細データ
|
|
569
|
+
entity 仕訳貸借明細データ
|
|
570
|
+
}
|
|
571
|
+
|
|
572
|
+
' 自動仕訳系
|
|
573
|
+
package "自動仕訳情報" {
|
|
574
|
+
entity 自動仕訳パターンマスタ
|
|
575
|
+
entity 自動仕訳管理データ
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
' 残高系
|
|
579
|
+
package "残高情報" {
|
|
580
|
+
entity 日次勘定科目残高
|
|
581
|
+
entity 月次勘定科目残高
|
|
582
|
+
}
|
|
583
|
+
|
|
584
|
+
' リレーション(簡略)
|
|
585
|
+
勘定科目マスタ ||--o{ 勘定科目構成マスタ
|
|
586
|
+
勘定科目マスタ }o--|| 課税取引マスタ
|
|
587
|
+
勘定科目マスタ ||--o{ 仕訳貸借明細データ
|
|
588
|
+
仕訳データ ||--o{ 仕訳明細データ
|
|
589
|
+
仕訳明細データ ||--o{ 仕訳貸借明細データ
|
|
590
|
+
勘定科目マスタ ||--o{ 日次勘定科目残高
|
|
591
|
+
勘定科目マスタ ||--o{ 月次勘定科目残高
|
|
592
|
+
部門マスタ ||--o{ 仕訳貸借明細データ
|
|
593
|
+
部門マスタ ||--o{ 日次勘定科目残高
|
|
594
|
+
部門マスタ ||--o{ 月次勘定科目残高
|
|
595
|
+
|
|
596
|
+
@enduml
|
|
597
|
+
```
|
|
598
|
+
|
|
599
|
+
| 分類 | 説明 | 例 |
|
|
600
|
+
|-----|------|-----|
|
|
601
|
+
| **マスタ情報** | 基本的に変更が少ない、システムの基盤となるデータ | 勘定科目マスタ、勘定科目構成マスタ、課税取引マスタ |
|
|
602
|
+
| **トランザクション情報** | 日々の業務で発生するデータ | 仕訳データ、日次勘定科目残高、月次勘定科目残高 |
|
|
603
|
+
|
|
604
|
+
### PostgreSQL ENUM 型定義
|
|
605
|
+
|
|
606
|
+
財務会計システムでは、業務で使用する区分値を PostgreSQL の ENUM 型で定義します。日本語のカラム名・テーブル名と同様に、ENUM 型名も日本語で定義します。
|
|
607
|
+
|
|
608
|
+
```sql
|
|
609
|
+
-- BSPL区分(貸借対照表/損益計算書区分)
|
|
610
|
+
CREATE TYPE "BSPL区分" AS ENUM ('BS', 'PL');
|
|
611
|
+
|
|
612
|
+
-- 貸借区分
|
|
613
|
+
CREATE TYPE "貸借区分" AS ENUM ('借方', '貸方');
|
|
614
|
+
|
|
615
|
+
-- 集計区分
|
|
616
|
+
CREATE TYPE "集計区分" AS ENUM ('集計', '明細');
|
|
617
|
+
|
|
618
|
+
-- 課税区分
|
|
619
|
+
CREATE TYPE "課税区分" AS ENUM ('課税', '非課税', '免税', '対象外');
|
|
620
|
+
|
|
621
|
+
-- 仕訳区分
|
|
622
|
+
CREATE TYPE "仕訳区分" AS ENUM ('通常', '振替', '決算', '自動');
|
|
623
|
+
|
|
624
|
+
-- 仕訳ステータス
|
|
625
|
+
CREATE TYPE "仕訳ステータス" AS ENUM ('入力中', '確定', '承認済', '取消');
|
|
626
|
+
|
|
627
|
+
-- 自動仕訳パターン区分
|
|
628
|
+
CREATE TYPE "自動仕訳パターン区分" AS ENUM ('売上', '仕入', '入金', '出金', '減価償却', '引当');
|
|
629
|
+
|
|
630
|
+
-- 決算区分
|
|
631
|
+
CREATE TYPE "決算区分" AS ENUM ('月次', '四半期', '中間', '年次');
|
|
632
|
+
```
|
|
633
|
+
|
|
634
|
+
| ENUM 型名 | 説明 | 値 |
|
|
635
|
+
|-----------|------|-----|
|
|
636
|
+
| BSPL区分 | 貸借対照表/損益計算書の区分 | BS, PL |
|
|
637
|
+
| 貸借区分 | 勘定科目の借方/貸方区分 | 借方, 貸方 |
|
|
638
|
+
| 集計区分 | 勘定科目の集計/明細区分 | 集計, 明細 |
|
|
639
|
+
| 課税区分 | 消費税の課税区分 | 課税, 非課税, 免税, 対象外 |
|
|
640
|
+
| 仕訳区分 | 仕訳の種類 | 通常, 振替, 決算, 自動 |
|
|
641
|
+
| 仕訳ステータス | 仕訳の処理状態 | 入力中, 確定, 承認済, 取消 |
|
|
642
|
+
| 自動仕訳パターン区分 | 自動仕訳の発生パターン | 売上, 仕入, 入金, 出金, 減価償却, 引当 |
|
|
643
|
+
| 決算区分 | 決算処理の種類 | 月次, 四半期, 中間, 年次 |
|
|
644
|
+
|
|
645
|
+
---
|
|
646
|
+
|
|
647
|
+
## 本章のまとめ
|
|
648
|
+
|
|
649
|
+
本章では、財務会計システムの全体像を把握しました。
|
|
650
|
+
|
|
651
|
+
### 学んだこと
|
|
652
|
+
|
|
653
|
+
| カテゴリ | 内容 |
|
|
654
|
+
|----------|------|
|
|
655
|
+
| スコープ | 債権管理・債務管理・経理(仕訳・決算) |
|
|
656
|
+
| 連携 | 販売管理・購買管理・生産管理からの仕訳データ受領 |
|
|
657
|
+
| 財務会計 | 外部報告目的(法定開示) |
|
|
658
|
+
| 管理会計 | 内部意思決定目的(任意) |
|
|
659
|
+
| アーキテクチャ | ヘキサゴナルアーキテクチャ(ポート&アダプター) |
|
|
660
|
+
| 設計手法 | ドメイン駆動設計(集約・リポジトリ・ドメインサービス) |
|
|
661
|
+
| 技術スタック | Java 25、Spring Boot 4.0.0、MyBatis 4.0.0、PostgreSQL 16 |
|
|
662
|
+
| 環境設定 | FAS: ポート 8081、PostgreSQL 5433 / SMS: ポート 8080、PostgreSQL 5432 |
|
|
663
|
+
| ENUM 型 | 8 種類の業務区分を PostgreSQL ENUM で日本語定義 |
|
|
664
|
+
|
|
665
|
+
### 次章の予告
|
|
666
|
+
|
|
667
|
+
第15章では、財務会計システムの基盤となる勘定科目マスタの設計を行います。勘定科目コード、BSPL区分、貸借区分、集計区分などの詳細を解説します。
|