我对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);
答案 0 :(得分:4)
不要使用像List
或Map
这样的通用结构,而是设计用于模拟所需结构的类。例如,在上面的例子中,你可能会有类似的东西:
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;地图的关键。
荣誉......享受