order by 子查询_【框架】118:mybatis之多表高级查询

今天是刘小爱自学Java的第118天。

感谢你的观看,谢谢你。

27b57b1108fe9b47eb505816bc2e938b.png

学习内容安排如下:

  • 补充说明知识点:resultMap,sql片段。
  • mybatis中的高级查询,即多表关联查询。
  • 查询主要分为:一对一,一对多,多对多,本来打算全学完的,奈何计划赶不上变化。

一、知识点补充

1resultMap

又要提到前面那个说了好几遍的起别名问题了,使用resultMap标签也能解决这个问题。

当然该标签最主要的应用还是在于多表关联查询,先对其有个初步了解:

67aff980e01ac252947763f668e7fe78.png

select标签中resultMap的值为userMap,根据这个值找到对应id的resultMap标签。

这样的一个好处在于独立出来了一个标签,我们在该标签里面可以做很多事情。

上述中就可以在resultMap标签中使用type属性说明,其对应的实体类为User。

使用result子标签也可以将数据表中的字段和实体类属性关联起来:

  • column对应的也就是数据库中的列名。
  • property对应的也就是实体类的属性。

当然取别名的方法还是使用settings开启驼峰匹配方便,不过resultMap也有其它的应用。

2sql片段

我们先看两条sql语句:

8d515baaeb7fd4066665e89e7fe997ff.png

在sql语句中,*号是大忌,它的出现也就意味着性能低下,一般都不会直接用它。

在这里使用将所有列名都书写的查询方式,这两条sql语句本质上其实就是一回事。

当然具体如何优化sql语句,应该没这么简单,我只是以此引出sql片段这个知识点。

如果每次都要书写这么长的sql语句,显然是一件很麻烦的事情。

所以为了解决这个问题,使用sql片段:

d916ccf25988755e6e06c4bbcb15d18d.png

将sql语句经常被使用的部分抽取成一个sql片段,在sql语句中使用标签引用该片段即可。

当然关于sql片段我们专门创建一个xml文件存放,再引用对应的片段也是可以的。

不过要注意:在核心配置文件中别忘了引入该映射文件,我这边就不说详述了。

3高级查询引入

表与表之间的关系,无外乎就是三种:

  • 一对一关系:比如用户和订单关系。
  • 一对多关系:比如订单和订单详情关系。
  • 多对多关系:比如订单和商品的关系。

二、一对一查询

案例:根据订单号,查询出订单信息,以及下单人信息。

1案例分析

5692cd05f3a8048be9d9a2cd7d37e0a1.png

①需求分析

因为涉及到订单信息表,和下单人信息表两张表的信息,所以需要使用到多表关联查询。

②查询结果

其结果有两张表的数据,那么如何在Java中接受查询到的数据呢?

我们知道数据表可以对应一个Java实体类,现在有多张表数据如何对应一个Java实体类?

就可以使用③这种方式,将User实体类对象作为Order实体类的成员变量。

2代码编写

5eb26fdaa689aa3cf646520e43032cfd.png

①mapper层接口方法

根据订单号查询订单和用户,参数为订单号,结果为一个order对象。

②映射文件sql语句编写

这不用多说,上述就已经分析了。

③测试代码

我们会发现其查询结果中,order实体类中的user属性为null

为什么会这样呢?

因为mybatis并不能自动映射user实体类,所以需要自行配置resultMap。

3代码优化

4b562271f67f0aff590e01d747c79b48.png

①结果集类型为order

指定结果集id,编写对应的resultMap标签。

②association标签

其翻译过来本身就是联合的意思。

  • property:也就是order中需要关联的属性,这里也就是user。
  • javaType:关联属性对应的Java类型,这里也就是User实体类。

③关联属性id

User的id在order中对应的也就是user_id。

再次测试查询时,就能发现查询结果中user类中的数据也能获取了。

三、一对多查询

案例:查询订单,查询出下单人信息并且查询出订单详情。

653a1c5994676e61b8a23dbe0d550c9f.png

①sql语句编写

查询结果与三张表相关联,那么一共有两次表关联查询。

②数据库查询结果

通过结果我们可以发现一个订单号查询出了2个订单详情。

③Order实体类拓展

订单和订单详情是一对多关系,那么同理,将订单详情的集合封装成订单的一个属性。

分析完毕,代码编写,同样的方式使用resultMap标签,一次性将代码写完整。

55bc938be2df14a5d666cff2d7cb0a41.png

①mapper层接口方法说明

②映射文件中sql语句编写

③一对多查询,collection标签,其本身翻译过来也就是集合的意思:

  • property:属性名,这里也就是封装到Order类中的orderdetails属性。
  • javaType:集合类型,我们封装的是List。
  • ofType:集合中的元素类型,即泛型。
  • autoMapping:开启自动映射

id子标签:要指定在查询结果中orderdetail表中的id,其id我们使用了起别名的方式加以说明,也就是detail_id。

最后

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/503702.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小程序使用css变量,小程序使用css变量实现“换肤”方案

使用sass,stylus可以很方便的使用变量来做样式设计,其实css也同样可以定义变量,在小程序中由于原生不支持动态css语法,so,可以使用css变量来使用开发工作变简单。基础用法page {--main-bg-color: brown;}.one {color: white;backg…

笔试MySQL读写速度优化_笔试题:优化mysql数据库的方法

优化mysql数据库的方法,(1).数据库设计方面,这是DBA和Architect的责任,设计结构良好的数据库,必要的时候,去正规化(英文是这个:denormalize,中文翻译成啥我不知道),允许部分数据冗余,避免JOIN操作,以提高查询效率(2).系统架构设计方面,表散列,把海量数据散列到几个不…

css找某个元素的下个子元素,CSS可以检测一个元素有多less个子元素?

注:这个解决scheme将返回一定长度的子集,而不是你所要求的父元素。 希望它仍然有用。安德烈路易斯提出了一个方法: http : //lea.verou.me/2011/01/styling-children-based-on-their-number-with-css3/不幸的是,它只适用于IE9及以…

python文本聚类分析_python机器学习kmeans算法——对文本进行聚类分析

#!/usr/bin/env python#-*- coding: utf-8 -*-#File : kmeans.py#Author: 田智凯#Date : 2020/3/19#Desc :机器学习kmeans算法,对科技成果项目进行聚类分析 from __future__ importprint_functionimporttimefrom sklearn.feature_extraction.text importTfidfVector…

lock字段mysql_MySQL的lock tables和unlock tables的用法(转载)

早就听说lock tables和unlock tables这两个命令,从字面也大体知道,前者的作用是锁定表,后者的作用是解除锁定。但是具体如何用,怎么用,不太清楚。今天详细研究了下,总算搞明白了2者的用法。lock tables 命令…

css中变形,css3中变形处理

transfrom功能在css3 中可以使用transfrom功能实现文字或图像的旋转,缩放,倾斜,移动等变形处理deg是css3中使用的一种角度单位。旋转: 使用rotate方法,在参数中加入角度值,在角度值后要加上角度单位deg。旋…

获取 子文件夹 后缀_后期制作老司机教你一键批量生成项目文件夹

我猜你的项目工程是这样的,当你老板说去修改一下之前几个月的工程的时候,你都不知道哪个工程才是最终版呀。乱糟糟的工程而且当你打开工程的时候,wo艹,素材怎么丢失了~~不管是后期制作者还是平常我们日常工作,一定要养…

mysql排序行号_mysql 取得行号后再排序

一.理论准备Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等。TreeMap:基于红黑树(Red-Black tree)的 NavigableMap 实现,该映射根据其键的自然顺序进行排序,或者根据创建映射…

ffmpeg将文件转码后推向服务器,使用 Serverless 云函数 + ffmpeg 实现音视频转码服务...

核心价值视频应用、社交应用等场景下,用户上传的图片、音视频的总量大、频率高,对处理系统的实时性和并发能力都有较高的要求。例如:对于用户上传的视频短片,我们可以使用多个云函数对其分别处理,对应不同的清晰度(108…

python 怎么判断字符串是否有换行_JAVA中如何判断一个字符串是否换行

展开全部${rr.right_name}扩展资料 java控制台程序判断String字符e68a8462616964757a686964616f31333431373263串中只输入了一个回车: importjava.io.BufferedReader; importjava.io.InputStreamReader; importjava.util.Scanner; publicclassTest{ publicstaticvoi…

python提取文本中的字符串到新的txt_Python实现jieba对文本分词并写入新的文本文件,然后提取出文本中的关键词...

版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。 Python实现jieba对文本分词并写入新的文本文件,然后提取出文本中的关键词思想 先对文本进行读写操作,利用jieba分词对待分词…

logger 参数列表过长_[源码级解析] 巧妙解决并深度分析Linux下rm命令提示参数列表过长的问题...

在维护实习单位服务器的过程中,偶然发现一个有350万文件的文件夹需要清理,于是我习惯性执行了rm -rf ./*,却在数秒后被告知“参数列表过长”。在一番折腾过后,我终于通过取巧的办法完成了这一任务,也随着相关内核源码的…

collect的功能是什么?其底层如何实现的?_为什么你要用 Spring ?

前言现在Spring几乎成为了Java在企业级复杂应用开发的代名词,得益于Spring简单的设计哲学和其完善的生态圈,确实为廉颇老矣,尚能饭否的 Java 带来了“春天”,有很多同学刚接触Java就直接从Spring框架开始学习,导致产生…

2.3.0配置 spark_配置scala 2.11.12的spark-2.3.0 maven依赖项的问题

我在尝试在POM.xml中为spark-scala应用程序设置maven denpendency时遇到问题 .我在用 :SCALA版本$ scalaWelcome to Scala 2.11.8 (OpenJDK 64-Bit Server VM, Java 1.8.0_162).SPARK版本:$ ./spark-shellWelcome to SPARK version 2.3.0Using Scala ver…

m3u8合并mp4软件_m3u8格式转mp4究极办法!

你们来这个号这么久了!还没给你们分享过一些实用的干货。打今天起这个公众号将给大家推荐一些APP和实用的小软件和一些小教程。生命太短,没时间留给遗憾。若不是终点,都不要把自己留在原地,请一直微笑向前!我是帮忙坏哥…

android 左移动画_android旋转动画和平移动画详解,补充说一下如果制作gif动画放到csdn博客上...

先上效果图:制作过程是先起一个模拟器,然后把GifCam的框拖到模拟器上面,点击Rec的new先,然后点击Rec,然后就save到本地成gif文件这里做一个左右旋转,上下旋转,和左右移动的动画,先自己建立一个View的类&…

vm虚拟机安装包_一次Miniconda虚拟机安装的神奇踩坑记录

本人一直都是在物理机环境下使用Anaconda,好处是提供了比较完全的机器学习包,还有方便的虚拟环境,缺点是体积太大。但如果直接用Anaconda中的根目录环境作为pycharm中的Python解释器,因为在运行程序前会不断加载根目录中的Python包…

css3弧形跑道效果_Css 实现漂亮弧形

在实现页面五花八门的有特色的ui时,我们有时会遇到要用实现一个弧形,而这样的弧形要怎么实现呢?用图片?好像不大现实,因为这样就要无故多加载一张图片了,这里我们来说说怎么用css的after伪类来实现弧形。先…

python螺旋圆的绘制_python 使用turtule绘制递归图形(螺旋、二叉树、谢尔宾斯基三角形)...

插图工具使用Python内置的turtle模块,为什么叫这个turtle乌龟这个名字呢,可以这样理解,创建一个乌龟,乌龟能前进、后退、左转、右转,乌龟的尾巴朝下,它移动时就会画一条线。并且为了增加乌龟画图的艺术价值…

教室信息管理系统mysql_教师信息管理系统(方式一:数据库为oracle数据库;方式二:存储在文件中)...

方式一:运行截图数据库的sql语句:/*Navicat Oracle Data TransferOracle Client Version : 12.1.0.2.0Source Server : ORCZYTSource Server Version : 120100Source Host : localhost:1521Source Schema : C##ZYTTarget Server Type : ORACLETarget Ser…