@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,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区分、貸借区分、集計区分などの詳細を解説します。