广告
返回顶部
首页 > 资讯 > 精选 >mybatis怎么利用resultMap复杂类型list映射
  • 901
分享到

mybatis怎么利用resultMap复杂类型list映射

2023-06-20 18:06:17 901人浏览 泡泡鱼
摘要

这篇文章主要介绍“mybatis怎么利用resultMap复杂类型list映射”,在日常操作中,相信很多人在mybatis怎么利用resultMap复杂类型list映射问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家

这篇文章主要介绍“mybatis怎么利用resultMap复杂类型list映射”,在日常操作中,相信很多人在mybatis怎么利用resultMap复杂类型list映射问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mybatis怎么利用resultMap复杂类型list映射”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

mybatis resultMap复杂类型list映射

映射泛型为对象

xml
<resultMap id="internetDataDTO" type="com.mdm.skr.mdm_common.dto.StrategyInternetDataDTO">    <id property="id" column="id" jdbcType="INTEGER"/>    <result property="internetData" column="internet_data" jdbcType="INTEGER"/>    <collection property="userList" ofType="com.mdm.skr.mdm_common.entity.SysUser">        <id property="id" column="id" jdbcType="INTEGER"/>        <result property="number" column="number" jdbcType="VARCHAR"/>        <result property="pushToken" column="push_token" jdbcType="VARCHAR"/>        <result property="wsChannelId" column="ws_channel_id" jdbcType="VARCHAR"/>    </collection></resultMap>  <select id="selectInternetDataDTOByInternetDataidList" resultMap="internetDataDTO">      SELECT sidu.id, sidu.internet_data, su.id, su.number, su.push_token, su.ws_channel_id      FROM strategy_internet_data_user sidu JOIN skr_user su on su.id = sidu.user_id      WHERE sidu.id IN      <foreach collection="internetDataIdList" open="(" close=")"          separator="," item="internetDataId">          #{internetDataId}      </foreach></select>
DTO
@Datapublic class StrategyInternetDataDTO {     private Integer id ;    private Integer internetData ;    private List<SysUser> userList ; }
ENTITY
@Datapublic class SysUser {     private Integer id;    private String number;    private String pushToken;    private String wsChannelId ; }
MAPPER
List<StrategyInternetDataDTO> selectInternetDataDTOByInternetDataIdList(@Param("internetDataIdList") List<Integer> internetDataIdList);

映射泛型为包装类型

xml
<resultMap id="internetDataDTO" type="com.mdm.skr.mdm_common.dto.StrategyInternetDataDTO">    <id property="id" column="id" jdbcType="INTEGER"/>    <result property="internetData" column="internet_data" jdbcType="INTEGER"/>    <collection property="userIdList" ofType="java.lang.Integer" javaType="java.util.List">        <result column="userId"/>    </collection></resultMap>   <select id="selectInternetDataDTOByInternetDataIdList" resultMap="internetDataDTO">      SELECT sidu.id, sidu.internet_data, sidu.user_id userId      FROM strategy_internet_data_user sidu      WHERE sidu.id IN      <foreach collection="internetDataIdList" open="(" close=")"          separator="," item="internetDataId">          #{internetDataId}      </foreach></select>
DTO
@Datapublic class StrategyInternetDataDTO {     private Integer id ;    private Integer internetData ;    private List<Integer> userIdList ; }
MAPPER
List<StrategyInternetDataDTO> selectInternetDataDTOByInternetDataIdList(@Param("internetDataIdList") List<Integer> internetDataIdList);

mybatis的几种传值方式

1.单个参数传参
User selectUserInfo(Integer userId);<select id = "selectUserInfo" parameterType = "java.lang.Inte" resultMap="BaseResultMap" >    select    <include refid="Base_Column_List" />    from user    where userId = #{userId , jdbcType=INTEGER}</select>
2. 按照顺序传参
User selectUserInfo(Integer userId, String userName, String userPass);<select id = "selectUserInfo" resultMap="BaseResultMap" >    select    <include refid="Base_Column_List" />    from user    where userId = #{arg0} and userName = #{arg1} and userPass = #{arg2}</select>
3. 使用@Param注解传参
User selectUserInfo(@Param("userName")String userName, @Param("userPass")String userPass);<select id = "selectUserInfo" resultMap="BaseResultMap" >    select    <include refid="Base_Column_List" />    from user    where userName = #{userName} and userPass = #{userPass}</select>
4. 使用Map传参 注意传参方式:parameterType="java.util.Map"
Map<String,Object> map = new HashMap();map.put("userName","张三");map.put("userPass","123");User user = userMapper.selectUserInfo(map);User selectUserInfo(Map<String,Object> map);<select id="selectUserInfo" parameterType="java.util.Map" resultMap="BaseResultMap" >    select    <include refid="Base_Column_List" />    from user    where userName = #{userName} and userPass = #{userPass}</select>
5. 实体对象传参
User user = new User();user.setUserName("张三");user.setUserPass("123");User user = UserMapper.selectUserInfo(user);User selectUserInfo(User record);<select id="selectUserInfo" parameterType="com.LiuXu.bean.User" resultMap="BaseResultMap" >    select    <include refid="Base_Column_List" />    from user    where userName = #{userName} and userPass = #{userPass}</select>
6. List传参
List<User> list = new ArrayList<>();list.add(user1);list.add(user2);List<User> userList = userMapper.selectUserInfo(list);    List<User> selectUserInfo(List<User> record);<select id="selectUserInfo" resultMap="BaseResultMap" >    select    <include refid="Base_Column_List" />    from user    where userId in    <foreach item="item" index="index" collection="list" open="(" separator="," close=")">        #{item}    </foreach></select>

到此,关于“mybatis怎么利用resultMap复杂类型list映射”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: mybatis怎么利用resultMap复杂类型list映射

本文链接: https://www.lsjlt.com/news/299173.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mybatis怎么利用resultMap复杂类型list映射
    这篇文章主要介绍“mybatis怎么利用resultMap复杂类型list映射”,在日常操作中,相信很多人在mybatis怎么利用resultMap复杂类型list映射问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家...
    99+
    2023-06-20
  • mybatis 如何利用resultMap复杂类型list映射
    mybatis resultMap复杂类型list映射 映射泛型为对象 xml <resultMap id="internetDataDTO" type="com.mdm....
    99+
    2022-11-12
  • 怎么使用MyBatis高级映射ResultMap解决属性问题
    本篇内容介绍了“怎么使用MyBatis高级映射ResultMap解决属性问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!ResultMap...
    99+
    2023-07-05
  • MybatisPlus怎么自定义TypeHandler映射JSON类型为List
    这篇文章将为大家详细讲解有关MybatisPlus怎么自定义TypeHandler映射JSON类型为List,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。自定义TypeHandler映射JSON类型为Li...
    99+
    2023-06-28
  • 映射器怎么利用MyBatis进行引入
    今天就跟大家聊聊有关映射器怎么利用MyBatis进行引入,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。mybatis引入映射器分为三种方式 1. 文件路径引入映射器<mappe...
    99+
    2023-05-31
    mybatis
  • 怎么在SpringBoot中利用Mybatis&Mybatis-plus映射文件
    本篇文章为大家展示了怎么在SpringBoot中利用Mybatis&Mybatis-plus映射文件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。springboot是什么springboo...
    99+
    2023-06-14
  • Python映射类型中dict怎么用
    这篇文章给大家分享的是有关Python映射类型中dict怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。映射类型 - dict字典可用多种方式来创建:使用花括号内以逗号分隔键: 值对的方式: {&ls...
    99+
    2023-06-29
  • mybatis中的SQL怎么利用注解进行映射
    今天就跟大家聊聊有关mybatis中的SQL怎么利用注解进行映射,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。结果集分页有时我们需要处理海量数据,由于数据量太大,所以不能一次取出所有...
    99+
    2023-05-31
    mybatis
  • 怎么解决mybatis映射和实际类型不一致的问题
    本篇内容主要讲解“怎么解决mybatis映射和实际类型不一致的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决mybatis映射和实际类型不一致的问题”吧!mybatis映射和实际类型...
    99+
    2023-06-21
  • mybatis中的映射文件怎么利用mapper接口进行加载
    mybatis中的映射文件怎么利用mapper接口进行加载?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。通过 mapper 接口加载映射文件,这对于后面 ssm三大框架 的整合...
    99+
    2023-05-31
    mybatis mapper pp
  • Spring中@Value注入复杂类型怎么用
    这篇文章主要为大家展示了“Spring中@Value注入复杂类型怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Spring中@Value注入复杂类型怎么用”这篇文章吧。为什么用,分割的字符...
    99+
    2023-06-22
  • Python中的复杂数据类型怎么使用
    这篇文章主要介绍“Python中的复杂数据类型怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python中的复杂数据类型怎么使用”文章能帮助大家解决问题。一、序列:序列是基类类型,序列扩展类...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作