json mysql javabean,通过java从mysql的数据创建json对象

After getting data from mysql, I need to export data as JSON,like the format as follows:

{"Thong tin":[{"Ngay":"2013-06-18","Tinh":"An Giang"},{"Ngay":"2013-06-17","Tinh":"Bình Dương"},{"Ngay":"2013-06-16","Tinh":"Bạc Liêu"}]}

But what i get , it's like

{"Thong tin":[{"Ngay":"2013-06-16","Tinh":"Bạc Liêu"},{"Ngay":"2013-06-16","Tinh":"Bạc Liêu"},{"Ngay":"2013-06-16","Tinh":"Bạc Liêu"}]}

Can you help me fix this error?

My code:

acc = new access();

rs2 = acc.query("select province_Name, date_Expired from thong_tin_khach_hang");

List province_Name = new ArrayList();

List date_Expired = new ArrayList();

try {

while (rs2.next()) {

province_Name.add(rs2.getString(1));

date_Expired.add(rs2.getString(2));

}

} catch (SQLException e) {

try {

acc.con.close();

} catch (SQLException e1) {

e1.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.

}

}

JSONObject obj = new JSONObject();

JSONArray jarray = new JSONArray();

try {

JSONObject ob = new JSONObject();

for (int i = 0; i < province_Name.size(); i++) {

ob=new JSONObject();

ob.put("Tinh", province_Name.get(i));

ob.put("Ngay", date_Expired.get(i));

jarray.add(ob);

}

obj.put("Thong tin", jarray);

} catch (JSONException e) {

e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.

}

out.print(obj);

解决方案

Here is the code that can help you out:

public String getJSONFromResultSet(ResultSet rs,String keyName) {

Map json = new HashMap();

List list = new ArrayList();

if(rs!=null)

{

try {

ResultSetMetaData metaData = rs.getMetaData();

while(rs.next())

{

Map columnMap = new HashMap();

for(int columnIndex=1;columnIndex<=metaData.getColumnCount();columnIndex++)

{

if(rs.getString(metaData.getColumnName(columnIndex))!=null)

columnMap.put(metaData.getColumnLabel(columnIndex), rs.getString(metaData.getColumnName(columnIndex)));

else

columnMap.put(metaData.getColumnLabel(columnIndex), "");

}

list.add(columnMap);

}

} catch (SQLException e) {

e.printStackTrace();

}

json.put(keyName, list);

}

return JSONValue.toJSONString(json);

}

Pass the resultset and your keyname into argument and get the Json String in response.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值