最近的工作是在数据库使用myBaties查出的数据没有实体,

比如:

<select id="allTree" parameterType="String" resultType="java.util.Map">
${sql}
</select>

这样查出来

直接是object或者是List<Object>的数据,需要自己去解析获取字段名和值。

一开始想用反射,但是t好像没法获取get Set方法吧,我有点懵,后来想到转成json会好获取一点。写了几个方法。

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set; import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
/**
* json 解析工具类
* @author heqiao
*
*/
public class JsonUtil {
/**
* 单个对象的所有键值
*
* @param object 单个对象
*
* @return Map<String, Object> map 所有 String键 Object值
* ex:{pjzyfy=0.00, xh=01, zzyl=0.00, mc=住院患者压疮发生率, pjypfy=0.00, rs=0, pjzyts=0.00, czydm=0037, lx=921, zssl=0.00}
*/
public static Map<String, Object> getValue(Object object) {
Map<String, Object> map = new HashMap<String, Object>();
Object obj = JSONObject.toJSON(object);//将对象转化为json格式对象
JSONObject jsonObject = JSONObject.parseObject(obj.toString());//转化为json对象
Set<String> s = jsonObject.keySet();//获取所有的键
for (String string : s) {
map.put(string, jsonObject.get(string));//根据键获取值
}
System.out.println("单个对象的所有键值===="+map.toString());
return map;
} /**
* 单个对象的某个键的值
* @param object 对象
*
* @param key 键
*
* @return Object 键在对象中所对应得值
*/
public static Object getValueByKey(Object object, String key) {
Object obj = JSONObject.toJSON(object);//将对象转化为json格式对象
JSONObject jsonObject = JSONObject.parseObject(obj.toString());//转化为JSONObject对象
System.out.println("单个对象的某个键的值===="+jsonObject.get(key));
return jsonObject.get(key);//根据键获取值
}
/**
* 多个(列表)对象的所有键值
* @param object
* @return List<Map<String,Object>> 列表中所有对象的所有键值
* ex:[{pjzyfy=0.00, xh=01, zzyl=0.00, mc=住院患者压疮发生率, pjypfy=0.00, rs=0, pjzyts=0.00, czydm=0037, lx=921, zssl=0.00},
* {pjzyfy=0.00, xh=02, zzyl=0.00, mc=新生儿产伤发生率, pjypfy=0.00, rs=0, pjzyts=0.00, czydm=0037, lx=13, zssl=0.00},
* {pjzyfy=0.00, xh=03, zzyl=0.00, mc=阴道分娩产妇产伤发生率, pjypfy=0.00, rs=0, pjzyts=0.00, czydm=0037, lx=0, zssl=0.00},
* {pjzyfy=0.00, xh=04, zzyl=0.75, mc=输血反应发生率, pjypfy=0.00, rs=0, pjzyts=0.00, czydm=0037, lx=0, zssl=0.00},
* {pjzyfy=5186.12, xh=05, zzyl=0.00, mc=剖宫产率, pjypfy=1611.05, rs=13, pjzyts=7.15, czydm=0037, lx=13, zssl=0.00}]
*/
public static List<Map<String,Object>> getValues(List<Object> object) {
List<Map<String,Object>> list=new ArrayList<Map<String,Object>>();
Object obj=JSONArray.toJSON(object);//转化为JSONArray格式
JSONArray jarr = JSONArray.parseArray(obj.toString()); //转化为JSONArray对象
for (Iterator<Object> iterator = jarr.iterator(); iterator.hasNext();) {
JSONObject job = (JSONObject) iterator.next();
Set<String> s=job.keySet();
Map<String,Object> listChild=new HashMap<String,Object>();
//获取对象所有键值
for (String string : s) {
listChild.put(string, job.get(string));
}
//将对象添加到列表中
list.add(listChild);
}
System.out.println("多个(列表)对象的所有键值===="+list.toString());
return list;
}
/**
* 多个(列表)对象的某个键的值
* @param object
* @param key 要查找的值的字段名
* @return List<Object> 键在列表中对应的所有值
* ex:[住院患者压疮发生率, 新生儿产伤发生率, 阴道分娩产妇产伤发生率, 输血反应发生率, 剖宫产率]
*/
public static List<Object> getValuesByKey(List<Object> object, String key) {
Object obj=JSONArray.toJSON(object);//将对象转化为json格式对象
JSONArray jarr = JSONArray.parseArray(obj.toString());
List<Object> list=new ArrayList<Object>();
for (Iterator<Object> iterator = jarr.iterator(); iterator.hasNext();) {
JSONObject job = (JSONObject) iterator.next();
list.add(job.get(key));//根据键获取值并添加到list中
}
System.out.println("多个(列表)对象的某个键的值列表===="+list.toString());
return list;
}
}

调用:

List<Object> o=treeService.allTree();

JsonUtil.getValue(o.get(0));
JsonUtil.getValueByKey(o.get(0), "mc");
JsonUtil.getValues(o);
JsonUtil.getValuesByKey(o, "mc");

json解析Object的更多相关文章

  1. php json 解析有stdClass Object 解决办法

    php json 解析有stdClass Object mixed json_decode ( string $json [, bool $assoc = false [, int $depth = ...

  2. Android okHttp网络请求之Json解析

    前言: 前面两篇文章介绍了基于okHttp的post.get请求,以及文件的上传下载,今天主要介绍一下如何和Json解析一起使用?如何才能提高开发效率? okHttp相关文章地址: Android o ...

  3. Json解析工具的选择

    前言 前段时间@寒江不钓同学针对国内Top500和Google Play Top200 Android应用做了全面的分析(具体分析报告见文末的参考资料),其中有涉及到对主流应用使用json框架Gson ...

  4. Android之JSON解析

    做个Android网络编程的同学一定对于JSON解析一点都不陌生,因为现在我们通过手机向服务器请求资源,服务器给我们返回的数据资源一般都是以JSON格式返回,当然还有一些通过XML格式返回,相对JSO ...

  5. Android总结之json解析(FastJson Gson 对比)

    前言: 最近为了统一项目中使用的框架,发现项目中用到了两种json解析框架,他们就是当今非常主流的json解析框架:google的Gson 和阿里巴巴的FastJson,为了废除其中一个所以来个性能和 ...

  6. Tomjson - 一个"短小精悍"的 json 解析库

    Tomjson,一个"短小精悍"的 json 解析库,tomjson使用Java语言编写,主要作用是把Java对象(JavaBean)序列化为json格式字符串,将json格式字符 ...

  7. ios基础篇(二十七)—— Json解析

    一.什么是Json JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使 ...

  8. Unity3d之json解析研究

    Unity3d之json解析研究     json是好东西啊!JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式      JSON简单易用,我要好好研究一下 ...

  9. 一个.NET通用JSON解析/构建类的实现(c#)转

    转自:http://www.cnblogs.com/xfrog/archive/2010/04/07/1706754.html NET通用JSON解析/构建类的实现(c#) 在.NET Framewo ...

随机推荐

  1. Windows终端工具_MobaXterm

    前言 有人喜欢小而美的工具,有人喜欢大集成工具.这里推荐一款增强型的Windows终端工具MobaXterm,它提供所有重要的远程网络工具(SSH,X11,RDP,VNC,FTP,MOSH ..... ...

  2. Linux一行命令处理批量文件

    前言 最好的方法不一定是你最快能想到的.这里提供一种使用sed命令构造命令解决处理批量文件的技巧,供参考. 需求案例1 将当前目录下所有的0_80_91.txt.0_80_92.txt.0_80_93 ...

  3. 修复Microsoft Store 无法连接网络 代码: 0x80072EFD

    事情的经过是这样的,我的Windows版本是1709,前两天刚从1703升上来,今天突然发现它自己给我装了个skype,我上Microsoft商店里查一下是什么情况,结果突然发现它又双双双不正常工作了 ...

  4. SpringBoot之基础

    简介 背景 J2EE笨重的开发 / 繁多的配置 / 低下的开发效率 / 复杂的部署流程 / 第三方技术集成难度大 特点 ① 快速创建独立运行的spring项目以及主流框架集成 ② 使用嵌入式的Serv ...

  5. 如何在ubuntu中安装php

    如何在ubuntu中安装php 情衅 | 浏览 692 次 发布于2016-05-07 12:36   最佳答案   关于Ubuntu下的LAMP配置步骤: 首先要安装LAMP 就是Apache,PH ...

  6. Java8内置的函数式接口

    JDK 1.8 API 包含了很多内置的函数式接口.其中就包括我们在老版本中经常见到的 Comparator 和 Runnable,Java 8 为他们都添加了 @FunctionalInterfac ...

  7. 利用Access-Control-Allow-Origin响应头解决跨域请求原理

    传统的跨域请求没有好的解决方案,无非就是jsonp和iframe,随着跨域请求的应用越来越多,W3C提供了跨域请求的标准方案(Cross-Origin Resource Sharing).IE8.Fi ...

  8. java批量生成用例脚本-保留字关键词的用例脚本生成

    20171012新补丁包程序,程序整理了全部的关键字和保留字,支持 字段a = "字段b" 与 字段a = 字段b,并做了代码重构.对补丁包进行关键字专项测试,验证关键字保留字作为 ...

  9. 20175126Apollo 20175126《Java程序设计》结队编程项目——四则运算

    结队编程项目——四则运算 一.项目需求 自动生成小学四则运算题目(加.减.乘.除)统计正确率 支持整数 支持多运算符(比如生成包含100个运算符的题目) 支持真分数 需求分析: 生成四则运算:需要使用 ...

  10. 初次见面,C++(的博客作业)

    懵懂无知.编程是什么?要是你在两个月前问我这个问题,你可能只会得到一个回答“天知道”.依稀记得在初中,上电脑课的老师曾经触及过编程的皮毛(那时候也没有编程的概念,听的似懂非懂),旁边一个同学却在十分熟 ...