如果要把 Map<EnumType,List<DTO>>进行json后放入到数据库中是很方便的,唯一要注意的是枚举类型EnumType会进行toString操作存放,比如
{"MEMBER_CARD":[{"cardEntityId":"99180079","cardId":"186e245aca0e49fda00a36de7fee9fe1","code":"0000003366","id":"33ef1554cce743f0b6b1ad88041accae","isForceRatio":0,"mode":1,"name":"会员卡","ratio":100}]}
但是如果要反json操作回来的时候,就会遇到麻烦了。如果你用如下代码肯定是不行的:
Map<EnumType,List<DTO>> map = JSON.parSEObject(jsonText,Map.class)
这里给参考,注意JSONArray的使用:
Map<String,JSONArray> map = JSON.parSEObject(promotion.getContent(),Map.class); JSONArray jsonArray = map.get(Promotion.Type.MEMBER_CARD.toString()); CardDto cardDto = jsonArray.getObject(0,CardDto.class);