后台给前端传json的时候,在data里想要一个list<map<>>

 

查找数据库得到list<String>之后,要用map使字段名和值一一对应,比如:

  字段名 putPlace 值123 

  json格式要求:"data":[{"putPlace":"123"}]

  具体操作:

    1、新建listmap对象。

List<Map<String, String>> listmap = new ArrayList<>();

    2、遍历list,并且new一个Map<String,String>对象map,使用map.put(,)将键值对放到map中,左边是键,右边是值。

    3、将map放到listmap中,遍历结束。

for (int i = 0; i < list.size(); i++) {
            Map<String, String> map = new HashMap<>();
            map.put("putPlace", list.get(i));
            listmap.add(map);
        }

 

实例:

repository:

@Query(value = "select a.put_place \n" +
            "from casque as a join agent_casque_bind as b on a.id = b.casque_id and b.agent_id = ?1\n" +
            "group by a.put_place",nativeQuery = true)
    List<String> findPutPlace(String userId);

service:

/**
 * 获取代理商头盔投放场所(去重)
 * @param userId 代理商id
 * @return 结果
 */
public List<Map<String,String>> queryPutPlace(String userId){
        List<String> list = this.placeWatchCountRepository.findPutPlace(userId);
        List<Map<String, String>> listmap = new ArrayList<>();
        for (int i = 0; i < list.size(); i++) {
            Map<String, String> map = new HashMap<>();
            map.put("putPlace", list.get(i));
            listmap.add(map);
        }
        return listmap;
    }

controller:

/**
     * 获取代理商头盔投放场所(去重)
     * @param user 当前登陆用户
     * @return 结果
     */
    @GetMapping("/placeWatch/putPlace")
    public Result putPlaceQuery(@CurrentUser TokenModel user){
        Result result = new Result();
        try{
            List<Map<String, String>> list = this.placeWatchService.queryPutPlace(user.getId());
            return result.success(list);
        }catch (Exception e){
            e.printStackTrace();
            return result.failure(ErrorCodeType.FIND_ERR.getMsg());
        }
    }