- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在我的小项目中遇到了问题。我花了大约 4 天的时间,但还没有最好的解决方案。
这是我的源代码:
public static JSONObject fetchPersonCarInfo() throws Exception {
// get data from 2 tables: Cars and Manufacturer
String query = "SELECT * from mytable";
statement = connection.prepareStatement(query);
rs = statement.executeQuery();
JSONArray carsArray = null;
while(rs.next()) {
carObj.put("id", (new string(rs.getString("id"))));
carsArray.put(carObj);
for(int i=0 ; i< carsArray.length() ; i++) {
manufacturerObj.put(new String(rs.getString("manufacturer_id")), carsArray);
manufacturerObj.put(new String(rs.getString("manufacturer_name")), carsArray);
}
System.out.println(manufacturerObj.toString());
}
System.out.println("Ok");
}
catch (Exception e) {
// TODO Auto-generated catch block
if (connection != null) {
connection.close();
}
throw e;
}
finally {
if (connection != null) {
connection.close();
}
}
return manufacturerObj;
}
然后我构建我的代码并通过 url 进行部署,它似乎不正确并且有我预期的错误,这是我的结果 json 格式:
{
"1":
[
{
"manufacturer_id": "1",
"manufacturer_name": "Honda"
},
{
"id": "4",
"name": "Honda1",
"price": "66000"
}
],
}
我如何更改我的代码以构建正确的上述 json 格式。非常感谢...
最佳答案
carObj
部分很好,所以我建议将其作为一种方法。
public static JSONObject getCarJSON(String id, String name, String price) {
JSONObject carObj = new JSONObject();
carObj.put("id", id);
carObj.put("name", name);
carObj.put("price", price);
return carObj;
}
您的问题似乎出在这里。您正在添加 personCarObj
到 carsArray
.那应该只是包含汽车。
JSONObject personCarObj = new JSONObject();
personCarObj.put("manufacturer_id", (new String(rs.getString("manufacturer_id"))));
personCarObj.put("manufacturer_name", (new String(rs.getString("manufacturer_name"))));
carsArray.put(personCarObj);
还有这里。对于 carsArray
中的每辆“汽车” ,您将键值对放入 manufacturerObj
其中值始终相同 carsArray
. manufacturerObj
应该只是包含制造商信息。
for(int i=0 ; i< carsArray.length() ; i++) {
manufacturerObj.put(new String(rs.getString("manufacturer_id")), carsArray);
manufacturerObj.put(new String(rs.getString("manufacturer_name")), carsArray);
}
因此,根据这些建议,您想要尝试获得类似于最初显示的非 JSON 格式的内容。
{
"manufacturers": [{
"id": "1",
"name": "Honda",
"cars": [{
"id": "4",
"name": "Honda1",
"price": "66000"
}]
}, {
"id": "2",
"name": "Toyota",
"cars": [{
"id": "551",
"name": "Toyota51",
"price": "3233333"
}]
}]
}
下面的代码可能会很接近(警告:未测试)。该 map 的原因是在您已经看到制造商时进行捕获,然后附加数据而不是复制。
JSONArray manufacturerArray = new JSONArray();
HashMap<String, JSONArray> manufacturerMap = new HashMap<String, JSONArray>();
while(rs.next()) {
String mId = rs.getString("manufacturer_id");
JSONArray carsArray = manufacturerMap.get(mId);
if (carsArray == null) {
carsArray = new JSONArray();
manufacturerMap.put(mId, carsArray);
}
JSONObject manufacturer = new JSONObject();
manufacturer.put("id", mId);
manufacturer.put("name", rs.getString("manufacturer_name"));
String carId = rs.getString("id");
String carName = rs.getString("name");
String carPrice = rs.getString("price");
carsArray.put(getCarJSON(carId, carName, carPrice));
manufacturer.put("cars", carsArray);
manufacturerArray.put(manufacturer);
}
JSONObject result = new JSONObject();
result.put("manufacturers", manufacturerArray);
您可以使用 Jackson/Gson 来制作一些像这样的 POJO
class Manufacturer {
String id, name;
List<Car> cars;
}
class Car {
String id, name, price;
}
然后你会序列化一个List<Manufacturer>
关于java - JSONObject 和 JDBC 返回格式 json 不正确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39860082/
我找不到答案。尝试了很多网站,包括这个。我想知道问题出在哪里。 错误是:org.json.JSONException:java.lang.String类型的值连接无法转换为JSONObject 这是我
我从 Java 应用程序提交了一个查询,该查询在 Elasticsearch 服务器上运行时以字符串形式返回结果。我希望结果为 JSONObject 列表对象。我可以将字符串转换为 JSONObjec
我正在尝试解析 JSON 字符串,但在尝试获取嵌套对象时出现错误: JSONObject jsonObject = new JSONObject(jsonString); System.out.pri
我有这样的 API 输出: {"user" : {"status" : {"stat1" : "54", "stats2" : "87"}}} 我从这个 API 创建了一个简单的 JSONObject
我正在寻找一种方法来比较两个 JSONObjects 除了使用 JSONObject.toString().equals(JSONObject.toString()) 并遇到了这种类似的方法,但它的比
我在读取和写入 Json 文件时遇到问题。我想将一些内容附加到 json 文件中,但它无法正常工作:它只是放入一个新的 json 对象,而没有使用 ',' 将其与前一个对象分开。我在每个网站上到处搜索
我有 JSON 文件:“D://test.json”,它遵循 MongoDB 格式: { "key":"value" } { "embedded": { "key2": "value2" } } {
我想要一个像这样的 json 文件: { "resu0": {"item":"value"} "resu1": {"item":"value"} "resu2": {"item":"value"} }
我有一个像这样的 JSON { "result": { "issue_date": "xx-yy-zzzz", "father/husband": "TEST",
我想发送json,里面有另一个json对象,像这样 { "key1": "value1", "key2": "valu2", "content": {
private JSONObject insertJSONintoJSON(JSONObject newJSON, JSONObject parent) { Object[] a = pare
常规更新:我之前询问是否可以按原样获取 JSONObject 的值,以便稍后将其与覆盖的版本进行比较。我的第一次尝试是: JSONObject oldObj = new JSONObject(); p
我正在尝试创建一个具有特定键和空值的 JSONObject。但该值应该是 JSONObject 而不是 JSONArray。 我已经使用 localJson.append(key, JSONObjec
我得到的所有资源都是从 JSONArray 获取 JSONObject。但在这种情况下,我想获得“temp”的温度。我不认为它是数组的一部分。我怎样才能得到它? { "coord":{
我正在尝试解析 JSONObject 以获取 JSON 数组的数据。 但问题是 JSONParser 是 org.json.simple.JSONParser 中的一个类,而 JSONObject 位
我发现 variable instanceof JSONObject 有奇怪的行为。我有以下代码: Object value; try { value = customer.get(key);
JsonObject 和 JSONObject 有什么区别? 当我们使用 put、add 和 addproperty 方法时,我有点混淆 JsonObject 和 JSONObject。 提前致谢。
我想从 Another JSONObject 中的一个 JSONObject 中检索数据谁能告诉我如何取回它们 我的JSONObject是这样的 {"udetail":{"ID":238597,"Re
你是否注意到,如果你使用 put() 将一个 JSONObject 放入另一个 JSONObject,容器 JSONObject 将不会存储对第一个 JSONObject 的引用,而是一个新的 JSO
我的应用程序构建得很好,但是当我运行它时,当以下行尝试执行时,我不断收到异常: JSONObject json = new JSONObject(); 我收到以下异常: 异常 javax.servle
我是一名优秀的程序员,十分优秀!