广告
返回顶部
首页 > 资讯 > 后端开发 > Python >MyBatis中association的基本使用方法
  • 341
分享到

MyBatis中association的基本使用方法

2024-04-02 19:04:59 341人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录通过association对两表进行联表查询按照查询嵌套处理按照结果嵌套处理总结通过association对两表进行联表查询 student表属性如下 teacher表属性如下

通过association对两表进行联表查询

student表属性如下

teacher表属性如下

按照查询嵌套处理

  • 关于需求的sql稍微有点复杂时,可以打开右侧查询框进行语句的编写执行。

当使用以下时,查询出来存在问题

<select id="getStudentTeacher" resultType="Student" >
    select s.id,s.name,t.id, t.name from student s, teacher t where s.tid = t.id
</select>

思路:

  • 查询所有的学生信息
  • 根据查询出来的学生tid,寻找对应的老师

利用结果集映射,联系起来

编写接口

//    查询所有的学生信息以及对应的老师信息
List<Student> getStudent();

编写mapper配置文件

<select id="getStudent" resultMap = "StudentTeacher" >
    select * from student
</select>

<resultMap id="StudentTeacher" type="Student">
    <result property="id" column="id" />
    <result property="name" column="name" />
    <!--        复杂的属性需要单独处理
            对象:association
            集合:collection
-->
    <association property="teacher" column="tid" javaType="Teacher" select="getTeacher"/>

</resultMap>

<select id="getTeacher" resultType="Teacher">
    select * from teacher where id = #{nid}
</select>

测试得到结果

结果中嵌套了结果

一些注意问题:

  • teacher中的id的传递是根据student中得到的tid,将tid传给id,因此#{}中取什么名字都可以。
  • association将实体类的teacher属性对应上一个结果,这个结果是将tid作为参数参与下一条sql语句产生的。

按照结果嵌套处理

  • 个人认为这种方法更直观
  • 正确的查询
<!--按照结果嵌套处理-->
<select id="getStudent2" resultMap="StudentTeacher2" >
    select s.id sid,s.name sname,t.id tid, t.name tname
    from student s, teacher t
    where s.tid = t.id
</select>

<resultMap id="StudentTeacher2" type="Student">
    <result property="id" column="sid" />
    <result property="name" column="sname" />
    <association property="teacher" javaType="Teacher" >
        <result property="id" column="tid" />
        <result property="name" column="tname" />
    </association>
</resultMap>

查询出来的需要展现的结果都应该在resultMap中进行定义,否则会以默认值进行展示如下,在resultMap中注释掉tid和sname后,执行的结果

总结

到此这篇关于mybatis中association基本使用的文章就介绍到这了,更多相关MyBatis association使用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: MyBatis中association的基本使用方法

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

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

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

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

下载Word文档
猜你喜欢
  • MyBatis中association的基本使用方法
    目录通过association对两表进行联表查询按照查询嵌套处理按照结果嵌套处理总结通过association对两表进行联表查询 student表属性如下 teacher表属性如下...
    99+
    2022-11-13
  • mybatis的基本使用方法
    本篇文章给大家分享的是有关mybatis的基本使用方法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。具体代码如下所示:<configuration> <pr...
    99+
    2023-05-31
    mybatis
  • mybatis中一对一关系association标签的使用
    目录一对一关系association标签使用1、嵌套的resultMap2、嵌套的select语句association标签三种用法association的用法一assoc...
    99+
    2022-11-13
  • GoLang中Module的基本使用方法
    目录前言1、开启go module2、用goland打开项目(1)设置镜像地址(2)导入Gin包检查go module是否使用正常(3)使用Gin(4)执行、发送请求3、go mod...
    99+
    2023-01-09
    go module实现原理 go module使用
  • vue3中$refs的基本使用方法
    1、在vue2中可以通过this来访问到$refs,vue3中由于没有this所以获取不到了,但是官网中提供了方法来获取 知道了怎么获取后,我们结合ElementPlus来使用,因...
    99+
    2022-11-13
  • Collectors.toMap()的基本使用方法
    介绍: 1、Java 8 流的新类 java.util.stream.Collectors 实现了 java.util.stream.Collector 接口,同时又提供了大量的方法对流 ( stream ) 的元素执行 map and ...
    99+
    2023-09-06
    java Powered by 金山文档
  • GNS3的基本使用方法
    GNS3 基本使用方法1.一张基本的拓扑图需要一台路由器,一台交换机,PC一台这里是所有的路由器和交换机及PC,在GNS3里面将路由器直接拖到工作面板中是没有用的,因为每个路由器需要对应的镜像,如图所示:添加镜像的方法在这里面选择...
    99+
    2023-01-31
    使用方法
  • PowerShell的基本使用方法
    目录什么是powershell1.   如何启动PowerShell2.   如何运行程序、脚本和已有的软件3.   运行PowerShell命令4.   如何查找指定命令以及命令详...
    99+
    2022-11-12
  • JDBC基本使用方法
    JDBC基本使用方法 JDBC固定步骤: 加载驱动 String url="jdbc:mysql://localhost:3306/jdbcstudyuseUnicode=true&characterEncoding=utf-...
    99+
    2017-12-27
    JDBC基本使用方法
  • linux expect 的基本使用方法
    linux expect 的基本使用方法,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。expect -c "   set timeout -1;&...
    99+
    2023-06-06
  • Apache POI的基本使用方法
    今天就跟大家聊聊有关Apache POI的基本使用方法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基本介绍POIpache POI是用Java编写的免费开源的跨平台的Java AP...
    99+
    2023-06-25
  • mysql中find_in_set函数的基本使用方法
    前言 这是我最近新接触到的一个函数, 我在项目中的使用场景是这样的: 有一个应用类型表,表中有parentId字段和parentIds字段,前者为父级id,后者为多级父级id,在库中都是varchar类型,paren...
    99+
    2022-05-24
    mysql find_in_set函数 mysql find_in_set函数 in
  • Vue3中vuex的基本使用方法实例
    目录一、基本结构二、基本使用三、将store中的数据模块化后的使用1.模块化2.使用补充:如何改变vuex中的属性总结 一、基本结构 src/store/index.js中...
    99+
    2022-11-13
  • Flask-SQLALchemy基本使用方法
    目录数据库基本操作将数据添加到会话中示例:在视图函数中定义模型类常用的SQLAlchemy查询过滤器常用的SQLAlchemy查询执行器创建表:删除表插入一条数据一次插入多条数据查询...
    99+
    2022-11-11
  • 详解python中的json的基本使用方法
    在Python中使用json的时候,主要也就是使用json模块,json是以一种良好的格式来进行数据的交互,从而在很多时候,可以使用json数据格式作为程序之间的接口。 #!/usr/bin/env ...
    99+
    2022-06-04
    使用方法 详解 python
  • Linux中的awk数组的基本使用方法
    1.awk数组描述 在其他的编程语言中,数组的下标都是从0开始的,也就是说,如果想反向引用数组中 的第一个元素,则需要引用对应的下标[0],在awk中数组也是通过引用下标的方法,但是在awk中数组的下标是从1开始的,在其...
    99+
    2022-06-04
    linux awk 数组 awk 数组使用
  • JavaWeb.servlet的基本使用方法详解
    目录前言:一.实现servlet二.开发模式 三.继承Servlet 总结前言: 我们在前几篇文章里的web项目都是用jsp文件完成的,那么什么时候jsp算是学完...
    99+
    2022-11-13
  • PHP函数的基本使用方法
    在现代的网页应用程序中,PHP作为一种重要的服务器端编程语言,被广泛应用。PHP中的函数是一种可重用的代码块,不仅简化了代码的编写,而且提高了代码的可维护性和可读性。本文将介绍PHP函数的基本使用方法,以帮助读者更好地理解和应用PHP函数。...
    99+
    2023-05-22
    方法 PHP函数 基本使用
  • FTP命令的基本使用方法
    这篇文章主要介绍“FTP命令的基本使用方法”,在日常操作中,相信很多人在FTP命令的基本使用方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”FTP命令的基本使用方法”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-09
  • Android中bindService基本使用方法概述
    Android中有两种主要方式使用Service,通过调用Context的startService方法或调用Context的bindService方法,本文只探讨纯bindSe...
    99+
    2022-06-06
    方法 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作