当前位置: 首页 > news >正文

Mybatis @MapKey注解实现List转Map

文章目录

  • @MapKey介绍
  • @MapKey示例
    • - 传统的写法
    • - @MapKey的写法


@MapKey介绍

在MyBatis中,@MapKey 主要用于在映射查询结果到一个Map。

当你执行一个查询并期望返回一个Map时,你可以使用@MapKey来进行结果集的映射。而Mybatis内部会将查询到的结果映射为一个key-value的形式。

@MapKey示例

有这么一个场景,需要查询用户列表,并转为Map,map的key为用户ID。

User类:

@Data
@TableName("sys_user")
public class User implements Serializable {private static final long serialVersionUID = -6525322309638123441L;@PropIgnore@TableId(type = IdType.AUTO)private Integer userId;private String userName;private String password;private String salt;private String phone;private String sex;private String email;private String nickName;private String address;private Date createTime;private Date updateTime;
}

- 传统的写法

Controller:

    @ApiOperation(value="@MapKey获取用户列表",notes="@MapKey获取用户列表")@GetMapping("getUsers")public void getUsers() {List<User> userList = userMapper.getUsers();Map<Integer, User> userMap = userList.stream().collect(Collectors.toMap(User::getUserId, user -> user, (v1, v2) -> v1));}

Mapper:

List<User> getUsers();

Mapper.xml:

    <select id="getUsers" resultType="com.joker.pojo.User">select * from sys_user limit 100</select>

- @MapKey的写法

Controller:

    @ApiOperation(value="@MapKey获取用户列表",notes="@MapKey获取用户列表")@GetMapping("getUsers")public void getUsers() {Map<Integer, User> userMap = userMapper.getUserIdMapUsers();}

Mapper:

	@MapKey("userId")Map<Integer, User> getUserIdMapUsers();

注意:userId为User类的字段名称,而非数据库表的字段名称

Mapper.xml:

    <select id="getUserIdMapUsers" resultType="com.joker.pojo.User">select * from sys_user limit 100</select>
http://www.lryc.cn/news/497705.html

相关文章:

  • vue中使用socket.io统计在线用户
  • zotero中pdf-translate插件和其他插件的安装
  • 【Linux操作系统】多线程控制(创建,等待,终止、分离)
  • 二百七十八、ClickHouse——将本月第一天所在的那一周视为第一周,无论它是从周几开始的,查询某个日期是本月第几周
  • JVM八股文精简
  • 深入解析CMake中的find_package()命令:工作原理及实际应用示例
  • 使用数据层进行数据生命周期管理
  • Kubernetes架构原则和对象设计
  • 响应式编程一、Reactor核心
  • uniapp+vue3+ts请求接口封装
  • 【计算机网络】实验4:生成树协议STP的功能以及虚拟局域网VLAN
  • 基于Matlab BP神经网络的电力负荷预测模型研究与实现
  • java 21 多线程
  • Rust学习笔记_07——枚举和范围
  • 40分钟学 Go 语言高并发:服务性能调优实战
  • Windows通过指令查看已安装的驱动
  • Windows 11 如何配置node.js
  • AWTK fscript 中的 串口 扩展函数
  • yolov11剪枝
  • 智慧地图聚合(LockMap)标注系统开发说明文档
  • 「Mac畅玩鸿蒙与硬件36」UI互动应用篇13 - 数字滚动抽奖器
  • cuda12.1版本的pytorch环境安装记录,并添加到jupyter和pycharm中
  • Linux: network: nic: mellanox MRU初现
  • 深入理解红黑树的底层逻辑
  • 【数据结构】手搓链表
  • ThinkPHP场景动态验证
  • 在M3上面搭建一套lnmp环境
  • 【C++笔记】二叉搜索树
  • Fork/Join框架简介
  • Java项目实战II基于微信小程序的电子竞技信息交流平台的设计与实现(开发文档+数据库+源码)