Jackson CsvMapper 嵌套对象字段

Mol*_*Man 6 java csv jackson

我想使用 jackson CsvMapper 将 Pojos 序列化/反序列化为 csv 格式。我的pojos:

public class User implements Serializable {

    String name;

    @JsonUnwrapped(prefix = "||")
    Role role;

    String email;
}

public class Role implements Serializable {

    Long id;

    String name;
}
Run Code Online (Sandbox Code Playgroud)

我现在得到的:

name|email|||id|||name 
New User|newuser@gmail.com|1|User 
New User2|newuser2@gmail.com|1|User 
New User3|newuser3@gmail.com|1|User
Run Code Online (Sandbox Code Playgroud)

我期望获得以下分隔符的内容:

New User|newuser@gmail.com|||1|User 
Run Code Online (Sandbox Code Playgroud)

(只有用附加分隔符分隔的嵌套对象,而不是其字段,分隔符也必须应用于数据,而不仅仅是标题)此外,我需要在行内移动嵌套对象。例如预期结果:

New User|||1|User|||newuser@gmail.com 
Run Code Online (Sandbox Code Playgroud)

我当前的架构和序列化代码:

 CsvSchema userSchema = csvMapper
            .schemaFor(User.class)
            .sortedBy("name", "role.name", "role.id", "email")
            .withoutQuoteChar()
            .withColumnReordering(true)
            .withColumnSeparator('|')
            .withHeader();

        csvMapper.writer(userSchema).writeValueAsString(users);
Run Code Online (Sandbox Code Playgroud)