最近在做一个投票情况的用例,返回的结果打算放到JSON中

数据库的结果集如上图所示:optionkey代表选项,optionval代表其值

第一次做的时候考虑应该键值对应的关系,所以前台接到的json  应该以A:t ,B:p这种形式保存

则第一次写法:

Map m = new HashMap();
List<Map> l = restConversationService.getTPOptions(tmpId);//取结果集
Iterator<Map> it = l.iterator();
Map map=null;//存储结果集的行
Map optionMap = new HashMap();//定义一个新的键
while(it.hasNext())
{
map =(Map)it.next();
optionMap.put((String) map.get("optionkey"), (String) map.get("optionval"));
} m.put("optionMap", optionMap);
m.put("content",Base64.encode(tmp.get("content").toString().getBytes()));
tmp.put("content", m);//tmp里还有其他东西略,只看content就行

前台效果如上图所示,缺点:这更像是一个实体的两个属性,而非两条记录。且以后不能排序,扩展性不太好。

第二次尝试,为了排序,可不可以把KEY放到一个list,value放到一个list,实现一一对应。

Map m = new HashMap();
List<Map> l = restConversationService.getTPOptions(tmpId);
Iterator<Map> it = l.iterator();
Map map=null; List valList =new ArrayList();//定义两个list分别存放数据库取出的键和值
List keyList =new ArrayList(); while(it.hasNext())
{
map =(Map)it.next();
	keyList.add((String) map.get("optionkey"));//放键
valList.add((String) map.get("optionval"));//放值
}
m.put("optionkey", keyList);
m.put("optionval", valList);
m.put("content",Base64.encode(tmp.get("content").toString().getBytes()));
tmp.put("content", m);

效果:

缺点:似乎虽然有了排序但是键值关系不那么呼应了,且虽然不那么像1个实体的两个属性,但是感觉两者没太大关系。

那么看第三种写法:

Map m = new HashMap();
List<Map> l = restConversationService.getTPOptions(tmpId);
Iterator<Map> it = l.iterator();
Map map=null;
List dataList = new ArrayList();//存放格式与数据库保持一致,datalist里是MAP
while(it.hasNext())
{
map =(Map)it.next();
Map<String, String> dataMap = new HashMap<String, String>();//datalist要放的map
dataMap.put((String) map.get("optionkey"), (String) map.get("optionval"));//放入选项 和选项值的对应关系
dataList.add(dataMap); }
m.put("d", dataList); m.put("content",Base64.encode(tmp.get("content").toString().getBytes()));
tmp.put("content", m);

效果:

从上图看出,返回的JSON没有改变原来数据库存储的形式,仍然是两行记录,键值清晰。

返回的JSON除了完成功能需要,还要尽量不要改变数据库原型

深入了解Json转变为map的思想,附源代码2的更多相关文章

  1. json字符串转map

    <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</ar ...

  2. fastJson将json字符串转换为map

    public class JsonUtil { /** * 将json转化成map * @param jsonStr * @return */ public static Map<String, ...

  3. JSON字符串与Map互转

    //一.map转为json字符串 public static String map2jsonstr(Map<String,?> map){ return JSONObject.toJSON ...

  4. Json字符串转map集合

    第一步:在pom.xml中添加依赖; <dependency> <groupId>com.alibaba</groupId> <artifactId>f ...

  5. json字符串转Map、json数组

    json数组转map public static void main(String[] args){ String strArr = "[{\"0\":\"zh ...

  6. go语言之进阶篇json解析到map

    1.json解析到map(通过类型断言,找到值和value类型) 示例: package main import ( "encoding/json" "fmt" ...

  7. JSON字符串转换为Map

    本文是利用阿里巴巴封装的FastJSON来转换json字符串的.例子如下: package com.zkn.newlearn.json; import com.alibaba.fastjson.JSO ...

  8. [GO]json解析到map

    package main import ( "encoding/json" "fmt" ) var str string func main() { m := ...

  9. C++实现json字符串与map的转换

    开源资源库 jsoncpp-src-0.5.0.tar.gz:https://sourceforge.net/projects/jsoncpp/ jsoncpp-master.ziphttps://g ...

随机推荐

  1. 关于MSHTML

    本文翻译自http://msdn.microsoft.com/workshop/browser/mshtml/overview/overview.aspMSDN Home >  MSDN Lib ...

  2. 飞行模式下不让打开FM

     android 判断手机当前是否是飞行模式,在AirplaneModeEnabler中 提供了isAirplaneModeOn方法来判断当前是否是Airplane mode:public stati ...

  3. win32线程池代码(WinApi/C++)

    win32线程池代码(WinApi/C++) 健壮, 高效,易用,易于扩, 可用于任何C++编译器 //说明, 这段代码我用了很久, 我删除了自动调整规模的代码(因为他还不成熟)/********** ...

  4. Win32函数Sleep的精度测试

    用了三种方法,第一种使用高精度性能计数器:第二种是使用多媒体定时器,另一种是<Windows图形编程>里提供的CPU周期来获取.推荐第一种方式测量: 先看第一种: #include < ...

  5. 显示目录树命令tree

    -a:显示所有文件,包括隐藏文件 -d:只显示目录 -f:显示完整的文件名,包含路径 -L:显示目录树的深度 [root@rusky /]# tree -L -a -f /home /home |-- ...

  6. vim中systemverilog的高亮显示

    vim中systemverilog的高亮显示 Linux中的vim显示systemverilog语法高亮 windows中的gvim显示systemverilog语法高亮 Linux系统 查看打开vi ...

  7. 自定义key解决zabbix端口监听取值不准确的问题

         今天有一个朋友问到我一个关于zabbix监控tcp端口的问题,明明端口在监听,但是通过net.tcp,listen取值取到的却是0. 经过简单的goole发现这已经是一个历史悠久的问题: 问 ...

  8. PagerSlidingTabStrip的使用

    布局 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:too ...

  9. c - 每位数字尾部加空格

    /* input:一个4位整数. output:每位整数后紧跟一个空格的字符串. */ char * insert(char *s) { int len = strlen(s); * len + ); ...

  10. iOS开发中的MVC设计模式

    我们今天谈谈cocoa程序设计中的 模型-视图-控制器(MVC)范型.我们将从两大方面来讨论MVC: 什么是MVC? M.V.C之间的交流方式是什么样子的? 理解了MVC的概念,对cocoa程序开发是 ...