List<UserInfo> 转换成 Map<Long,List<UserInfo>>
时间: 2023-11-11 17:18:18 浏览: 165
要将List<UserInfo>转换成Map<Long,List<UserInfo>>,可以使用foreach标签来实现。首先,在mapper层的SysUserMapper.java文件中,可以定义一个方法来实现这个转换操作。方法的参数是List<UserInfo> userList,表示要转换的列表。在方法内部,可以使用Java的foreach循环遍历列表,将每个UserInfo对象的id作为键,将对象本身添加到对应的值列表中。最后,将键值对添加到一个Map<Long,List<UserInfo>>对象中,并将其返回。
下面是一种可能的实现方式:
```java
public Map<Long, List<UserInfo>> convertListToMap(List<UserInfo> userList) {
Map<Long, List<UserInfo>> resultMap = new HashMap<>();
for (UserInfo userInfo : userList) {
Long id = userInfo.getId();
if (resultMap.containsKey(id)) {
resultMap.get(id).add(userInfo);
} else {
List<UserInfo> list = new ArrayList<>();
list.add(userInfo);
resultMap.put(id, list);
}
}
return resultMap;
}
```
这样,当调用该方法并传入List<UserInfo>对象时,将返回一个Map<Long,List<UserInfo>>对象,其中每个键是UserInfo对象的id,对应的值是具有相同id的UserInfo对象列表。
请注意,以上只是一种可能的实现方式,具体的实现方式可能因具体需求而有所不同。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [Mybatis/Ibatis框架--动态SQL, foreach标签与List<T>、数组参数案例](https://blog.csdn.net/dear_Alice_moon/article/details/87534656)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文