@XlsNestedRecords

アノテーション @XlsHorizontalRecords もしくは @XlsVerticalRecords のレコード用クラスにおいて、ツリー構造のように入れ子になっている表をマッピングする際に使用します。 [ver.1.4+]

一対多の関係

一対多の関係を表現する際には、Collection(List/Set)または、配列で指定します。

  • 親子関係は、結合しているかで表現します。

    • 結合している個数が不一致の場合は、例外 NestedRecordMergedSizeException がスローされます。

  • 親に指定しているJavaBeanクラスは、子や孫には指定することができません。

    • カラムの定義はレコードに記述されているため、親子に同じレコードのクラス定義があると、無限に再帰処理してしまうため、それを防ぐための制約になります。

  • 属性 @XlsHorizotanlRecords#terminalLabel の終端の判定は、入れ子になったレコードごとに判定されます。

  • 読み込みの際、アノテーション @XlsIgnorable で、空のレコードを読み飛ばした結果、レコード数が0件となった場合は、要素数0個リストや配列が設定されます。

_images/NestedRecords_oneToMany.png

NestedRecords(一対多の関係)

 1// シート用クラス
 2@XlsSheet(name="機能")
 3public class SampleSheet {
 4
 5    @XlsHorizontalRecords(tableLabel="機能一覧")
 6    private List<CategoryRecord> categories;
 7
 8}
 9
10// レコード用クラス(分類)
11public class CategoryRecord {
12
13    @XlsColumn(columnName="分類")
14    private String name;
15
16    @XlsColumn(columnName="説明(分類)")
17    private String description;
18
19    // ネストしたレコードのマッピング
20    @XlsNestedRecords
21    private List<FunctionRecord> functions;
22
23}
24
25// レコード用クラス(機能)
26public class FunctionRecord {
27
28    @XlsColumn(columnName="機能名")
29    private String name;
30
31    @XlsColumn(columnName="説明(機能)")
32    private String description;
33
34    // ネストしたレコードのマッピング
35    @XlsNestedRecords
36    private List<DetailRecord> details;
37
38}
39
40// レコード用クラス(詳細)
41public class DetailRecord {
42
43    @XlsColumn(columnName="項目")
44    private String name;
45
46    @XlsColumn(columnName="値")
47    private String value;
48
49}

一対一の関係

一対一の関係をマッピングする際には、ネストしたクラスを直接指定します。

クラス定義などの制約は、基本的に一対多のときと同じです。

_images/NestedRecords_oneToOne.png

NestedRecords(一対一の関係)

 1// シート用クラス
 2@XlsSheet(name="学期末テスト")
 3public class SampleSheet {
 4
 5    @XlsHorizontalRecords(tableLabel="テスト結果", bottom=2)
 6    private List<UserRecord> users;
 7
 8}
 9
10// レコード用クラス(生徒情報)
11public class UserRecord {
12
13    @XlsColumn(columnName="No.")
14    private int no;
15
16    @XlsColumn(columnName="クラス", merged=true)
17    private String className;
18
19    @XlsColumn(columnName="氏名")
20    private String name;
21
22    // ネストしたレコードのマッピング
23    @XlsNestedRecords
24    private ResultRecord result;
25
26}
27
28// レコード用クラス(テスト結果)
29public class ResultRecord {
30
31    @XlsColumn(columnName="国語")
32    private int kokugo;
33
34    @XlsColumn(columnName="算数")
35    private int sansu;
36
37    @XlsColumn(columnName="合計")
38    private int sum;
39
40}