【Mybatis用法】Mybatis框架中一对一,一对多association和collection的使用举例方法

本文目录

一、association 标签(一对一)

二、collection 标签(一对多)


一、association 标签(一对一)

association通常用来映射一对一的关系,例如,有个类User,对应的实体类如下:(getter,setter方法省略)

@Data
public class User {
    /**
     * 主键
     */
    private String id;
    /**
     * 用户姓名
     */
    private String userName;
}

有个类Article,对应的实体类如下:

@Data
public class Article {
    /**
     * 主键
     */
    private String id;
    /**
     * 文章标题
     */
    private String articleTitle;
    /**
     * 文章内容
     */
    private String articleContent;
}

如果我想查询一个用户的时候,也查到他写的一篇文章,那么怎样写呢?其实可以在类User中加入一个属性Article类:

@Data
public class User {
    /**
     * 主键
     */
    private String id;
    /**
     * 用户姓名
     */
    private String userName;
    /**
     * 类Article
     */
    private Article article;
}

mapper.xml 我在user类的UserMapper.xml这样配置

<mapper namespace="com.uiot.practice.mysqltest.dao.UserMapper">
	<resultMap type="com.uiot.practice.mysqltest.entity.Article" id="articleMap">
		<id column="id" property="id" jdbcType="VARCHAR" javaType="java.lang.String"/>
		<result column="userName" property="userName" jdbcType="VARCHAR" javaType="java.lang.String"/>
		<!--这里把user的id传过去,com.uiot.practice.mysqltest为命名空间-->
		<association property="article" column="id" select="com.uiot.practice.mysqltest.selectArticleByUserId" />
	</resultMap>
</mapper>

同时,我的article对应的ArticleMapper.xml这样写:

<mapper namespace="com.uiot.practice.mysqltest.dao.ArticleMapper">
    <resultMap type="com.uiot.practice.mysqltest.entity.Article" id="ArticleResultMap">
        <id column="id" property="id" jdbcType="VARCHAR" javaType="java.lang.String"/>
        <result column="articleTitle" property="articleTitle" jdbcType="VARCHAR" javaType="java.lang.String"/>
        <result column="articleContent" property="articleContent" jdbcType="VARCHAR" javaType="java.lang.String"/>
    </resultMap>

    <select id="selectArticleByUserId" parameterType="java.lang.String" resultMap="ArticleResultMap">
        select * from tb_article where userId=#{userId}
    </select>
</mapper>

二、collection 标签(一对多)

一对多,collection,理解了一对一,一对多容易理解

@Data
public class User {
    /**
     * 主键
     */
    private String id;
    /**
     * 用户姓名
     */
    private String userName;
    /**
     * 类Article
     */
    private List<Article> articleList;
}

UserMapper.xml这样配置

<mapper namespace="com.uiot.practice.mysqltest.dao.UserMapper">
	<resultMap type="com.uiot.practice.mysqltest.entity.User" id="articleMap">
		<id column="id" property="id" jdbcType="VARCHAR" javaType="java.lang.String"/>
		<result column="userName" property="userName" jdbcType="VARCHAR" javaType="java.lang.String"/>
		<!--这里把user的id传过去,com.uiot.practice.mysqltest为命名空间-->
		<collection property="articleList" column="id" select="com.uiot.practice.mysqltest.selectArticleByUserId"/>
	</resultMap>
	<!--以下省略,类同,Mybatis会把结果封装成List类型。-->
</mapper>

 

完结!

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

No8g攻城狮

向每一个努力改变现状的你致敬!

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

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

打赏作者

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

抵扣说明:

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

余额充值