MyBatis使用 resultMap中collection过滤空字段

在使用MyBatis查询数据时,返回值可以定义为resultMap

如果返回的对象中有列表,还可以使用collection标签进行定义。

此时,如果不想某些字段为空的数据加入列表,可以使用notNullColumn属性进行定义:

<resultMap id="resultMapDemo" type="返回值类型" >
    <id property="id" column="id" />
    <result property="name" column="name"/>
    <collection property="childList" notNullColumn="id,name" ofType="列表项类型">
      <id property="id" column="id"/>
      <result property="name" column="name"/>
      <result property="age" column="age"/>
    </collection>
  </resultMap>

notNullColumn属性可以设置多个字段,用,分隔。

以上代码会过滤掉idname的数据加入列表,实现了resultMap中collection过滤空字段的功能。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MyBatisresultMap标签用于配置实体类与表字段的映射规则。该标签有以下作用: - 自定义映射规则,通过id属性给映射规则指定一个唯一标识,用于在其他地方引用。 - 使用id标签配置主键映射,指定实体类的属性和数据库表字段的对应关系。 - 使用result标签配置普通字段映射,指定实体类的属性和数据库表字段的对应关系。 举例来说,可以使用resultMap标签来配置一个名为studentmap的映射规则,该规则用于将数据库表字段与Student实体类的属性进行映射。其,id标签用于配置主键映射,result标签用于配置普通字段映射。例如: ```xml <resultMap id="studentmap" type="student"> <id property="sid" column="s_id"></id> <result property="sname" column="s_name"></result> <result property="sage" column="s_age"></result> <result property="sphone" column="s_phone"></result> </resultMap> ``` 此外,在核心配置文件,还可以通过设置lazyLoadingEnabled属性来开启延迟加载。如果使用的是MyBatis 3.41之前的版本,还需要配置aggressiveLazyLoading为true。同时,可以使用resultMap标签来配置一对多的映射关系,将一个教师对象对应多个学生对象。例如: ```xml <resultMap id="teacher" type="Teacher"> <id property="tid" column="t_id"></id> <result property="tname" column="t_name"></result> <result property="tage" column="t_age"></result> <collection property="students" ofType="student"> <id property="sid" column="s_id"></id> <result property="sage" column="s_age"></result> <result property="sname" column="s_name"></result> <result property="sphone" column="s_phone"></result> </collection> </resultMap> ``` 此外,可以使用association标签来配置多对一的映射关系,将多个学生对象对应一个教师对象。例如: ```xml <association property="teacher" javaType="Teacher"> <result property="tid" column="t_id"></result> <result property="tname" column="t_name"></result> <result property="tage" column="t_age"></result> </association> ``` 总结起来,resultMap标签在MyBatis用于配置实体类与表字段的映射规则,可以通过id、resultcollection、association等子标签来实现不同类型的映射关系的配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [mybatisResultmap标签的的使用](https://blog.csdn.net/weixin_43891398/article/details/125608434)[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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

入夏忆梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值