如何在java中创建具有不同数据类型的映射列表?

时间:2018-03-08 16:36:59

标签: java arrays list arraylist hashmap

我对Java不是很了解,所以请原谅我的无知。 我从一个表中选择并循环遍历结果集以创建一个列表,我可以使用它转换为json,它应该类似于以下示例。

{
    "ContactId": "123",
    "key": {
        "type": "email",
        "email": "emailAdress"
    },
    "address": "String",
    "source": "String",
    "revoked": true,
    "text": "String"
}

我不知道如何将它们放入列表中,因为我需要将不同的数据类型放入哈希映射中。 请注意,在exmaple上面键是一个对象,我试图在列表中实现相同的事情。 最终目标是将生成的列表转换为json。

我创建了一些哈希图,但我认为我没有采用正确的方法。

String Table = "TableName";
String sql = String.format("SELECT id_user, email FROM %s ", Table);
ResultSet res = dbConn.prepareStatement(sql).executeQuery();

Map<String, Map> keyObject = new HashMap<String, Map>();
Map<String, String> keyMap = new HashMap<String, String>();
Map<String, String> mainMap = new HashMap<String, String>();

List<Map<String, String>> contacts = new ArrayList<>();

int i = 0;
while(res.next()){
    keyMap.put("type", "email");
    keyMap.put("value", res.getString("email"));
    keyObject.put("key",  keyMap);
    mainMap.put("tenant", res.getString("id_user"));
    mainMap.put("purpose",  "Marketing sendouts");
    mainMap.put("legalBase",  "Withdrawn");
    contacts.add(i, map);
    i++;
}
System.out.println(contacts);

3 个答案:

答案 0 :(得分:4)

不要使用像ListMap这样的通用结构,而是设计用于模拟所需结构的类。例如,在上面的例子中,你可能会有类似的东西:

public class Contact {
    private int contactId;
    private ContactKey key;
    private String address;
    private String source;
    private boolean revoked;
    private String text;
    // ....
}

现在这是一个强类型结构,可以从结果集中轻松填充。像杰克逊(或许多其他人)这样的工具可以轻松地将其渲染为JSON。

答案 1 :(得分:0)

如果map是您首选的数据结构,则可以使用以下代码:

    Map<String, Object> map = new HashMap<>();
    map.put("ContactId", 123);

    Map<String, Object> keyMap = new HashMap<>();
    keyMap.put("type", "email");
    keyMap.put("email", "emailAdress");
    map.put("key", keyMap);

    map.put("address", "aaaa");

    ObjectMapper objectMapper = new ObjectMapper();
    try {
        String json = objectMapper.writer().withDefaultPrettyPrinter().writeValueAsString(map);
        System.out.println(json);
    } catch (JsonProcessingException e) {
        e.printStackTrace();
    }

我假设Jackson是您用于序列化的库。

答案 2 :(得分:0)

创建一个模型类并使用它的getter和setter方法。

例如

public class Model {

    private String id;

    private String name;

//Use constructor 
    public Model(String id, String name) { 

        this.id = id;

        this.name = name;

    }


    public String getId() {

        return id;

    }


    public void setId(String id) {

        this.id = id;

    }


    public String getName() {

        return name;

    }


    public void setName(String name) {

        this.name = name;

    }

}


// Now make your Map data Structure center code hereustom .

Hashmap<String,Model> Map = new Hashmap();

// Create a object of your custom Model datastructure and add data.
Model model = new Model("145","Jason");
Map.put("1st",model);

请注意,所有数据都存储在&#34; 1st&#34;地图的关键。

荣誉......享受