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
    评论
要将多个数据存入MySQL,可以按照以下步骤进行操作: 1. 在Android中获取多个数据,可以使用EditText等控件获取用户输入的数据。 2. 将获取到的数据封装成一个对象,可以使用JavaBean或者Map等数据结构。 3. 将封装好的对象转化为JSON格式的字符串,可以使用Gson等库来实现。 4. 使用HttpClient或者OkHttp等网络库向服务器发送POST请求,将JSON格式的字符串作为请求体发送给服务器。 5. 在服务器端接收到请求后,使用JSON解析库将请求体中的JSON格式字符串解析成对象,并将数据存入MySQL数据库中。 下面是一些具体的代码示例: 1. 创建JavaBean类: ``` public class User { private int id; private String name; private String email; // 省略getter和setter方法 } ``` 2. 将JavaBean转化为JSON格式字符串: ``` User user = new User(); user.setId(1); user.setName("Tom"); user.setEmail("tom@example.com"); Gson gson = new Gson(); String json = gson.toJson(user); ``` 3. 使用OkHttp发送POST请求: ``` OkHttpClient client = new OkHttpClient(); MediaType mediaType = MediaType.parse("application/json"); RequestBody body = RequestBody.create(mediaType, json); Request request = new Request.Builder() .url("http://example.com/user") .post(body) .build(); Response response = client.newCall(request).execute(); ``` 4. 在服务器端使用JSON解析库将请求体中的JSON格式字符串解析成对象,并将数据存入MySQL数据库中。具体实现可以参考以下代码: ``` String json = request.getParameter("json"); Gson gson = new Gson(); User user = gson.fromJson(json, User.class); Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "123456"); PreparedStatement ps = conn.prepareStatement("insert into user (id, name, email) values (?, ?, ?)"); ps.setInt(1, user.getId()); ps.setString(2, user.getName()); ps.setString(3, user.getEmail()); ps.executeUpdate(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值