java xml文件查询对象里面有一个集合字段

                                                       直接上代码以作笔记

 一、对象集合

        下述为对象集合的例子:

public class Info {

    @ApiModelProperty(value = "姓名")
    private String name;

    @ApiModelProperty(value = "性别")
    private String sex;

    @ApiModelProperty(value = "年龄")
    private Integer age;

    @ApiModelProperty(value = "爱好")
    private List<Hobby> list;
}

/** 此处为上面对象中的集合 */
public class Hobby {

    @ApiModelProperty(value = "爱好名称")
    private String name;

    @ApiModelProperty(value = "时长")
    private Integer duration;
}

下述为xml中的代码:

<resultMap type="Info" id="map">
        <result property="name"    column="name"   />
        <result property="sex"     column="sex"    />
        <result property="age"     column="age"    />
        
        <!-- 这个就是对应对象中集合的内容 property(字段名) ofType(对象名) -->
        <collection property="list" ofType="Hobby">
                        <!-- 要是有主键的话就解除这个 -->
            <!-- <id property="id"         column="id"          /> -->

            <result property="name"        column="name"        />
            <result property="duration"    column="duration"    />
        </collection>
</resultMap>

    
<select id="query" resultMap="map">
        SELECT
            user.name,
            user.sex,
            user.age,
            
            hobby.name,
            hobby.duration
        FROM t_user user
                    <!-- 此处关联以作假设 -->
                 LEFT JOIN t_hobby hobby ON hobby.user_id = user.id
</select>

二、基本数据类型集合

        基本数据类型的需要先用一个String类型来接受然后再方法体里用 ' , ' 分割一下遍历到集合中,这主要是因为所用到的GROUP_CONCAT函数是将查询到的数据用 ‘ , ’ 拼接并返回一个String类型

        下述为基本数据类型对象集合的例子:

public class Info {

    @ApiModelProperty(value = "姓名")
    private String name;

    @ApiModelProperty(value = "性别")
    private String sex;

    @ApiModelProperty(value = "年龄")
    private Integer age;

    @ApiModelProperty(value = "爱好")
    private String hobby;

    @ApiModelProperty(value = "爱好集合")
    private List<String> hobbyList;
}

下述为xml中的代码:

<resultMap type="Info" id="map">
        <result property="name"    column="name"   />
        <result property="sex"     column="sex"    />
        <result property="age"     column="age"    />
        <result property="hobby"   column="hobby"  />
</resultMap>

    
<select id="query" resultMap="map">
        SELECT
            user.name,
            user.sex,
            user.age,
            
 <!-- GROUP_CONCAT作用是将数据以作逗号拼接返回的是一个String类型所以需要String来接收 -->
            GROUP_CONCAT(hobby.name) as hobby
        FROM t_user user
                    <!-- 此处关联以作假设 -->
                 LEFT JOIN t_hobby hobby ON hobby.user_id = user.id
</select>

若有更好的方案请在评论区分享一下,谢谢,学海无涯

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值