Mysql—— 内连接、左连接、右连接以及全连接查询

Mysql—— 内连接、左连接、右连接以及全连接查询获取boy、girl表下载地址一、内连接查询innerjoin关键字:innerjoinon语句:select*froma_tableainnerjoinb_tablebona.a_id=b.b_id;说明:组合两个表中的记录,返回关联字段相符的记录,也就是返回两个表的交集(阴影)部分。案例解释:在boy表和girl表中查出…

大家好,又见面了,我是你们的朋友全栈君。

获取 boy 、girl 表下载地址

一、内连接查询  inner join

关键字:inner  join   on

语句select * from a_table a inner join b_table b on a.a_id = b.b_id;

说明:组合两个表中的记录,返回关联字段相符的记录,也就是返回两个表的交集(阴影)部分。

Mysql—— 内连接、左连接、右连接以及全连接查询

案例解释:在boy表和girl 表中查出两表 hid 字段一致的姓名(gname,bname),boy表和girl 表如下:

Mysql—— 内连接、左连接、右连接以及全连接查询      Mysql—— 内连接、左连接、右连接以及全连接查询

采用内连接查询方式:

SELECT boy.hid,boy.bname,girl.gname FROM boy INNER JOIN girl ON girl.hid = boy.hid;

查询结果如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

二、左连接查询 left join

关键字:left join on / left outer join on

语句:SELECT  * FROM a_table a left join b_table b ON a.a_id = b.b_id;

说明: left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。 左(外)连接,左表(a_table)的记录将会全部表示出来,而右表(b_table)只会显示符合搜索条件的记录。右表记录不足的地方均为NULL。

Mysql—— 内连接、左连接、右连接以及全连接查询

案例解释:在boy表和girl 表中左连接查询,boy表和girl 表如下:

Mysql—— 内连接、左连接、右连接以及全连接查询      Mysql—— 内连接、左连接、右连接以及全连接查询

采用内连接查询方式:

SELECT boy.hid,boy.bname,girl.gname FROM boy LEFT JOIN girl ON girl.hid = boy.hid;

查询结果如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

三、右连接 right join

关键字:right join on / right outer join on

语句:SELECT  * FROM a_table a right outer join b_table b on a.a_id = b.b_id;

说明:right join是right outer join的简写,它的全称是右外连接,是外连接中的一种。与左(外)连接相反,右(外)连接,左表(a_table)只会显示符合搜索条件的记录,而右表(b_table)的记录将会全部表示出来。左表记录不足的地方均为NULL。

Mysql—— 内连接、左连接、右连接以及全连接查询

案例解释:在boy表和girl 表中右连接查询,boy表和girl 表如下:

Mysql—— 内连接、左连接、右连接以及全连接查询      Mysql—— 内连接、左连接、右连接以及全连接查询

采用内连接查询方式:

SELECT boy.hid,boy.bname,girl.gname FROM boy RIGHT JOIN girl ON girl.hid = boy.hid;

查询结果如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

四、全连接 union

关键字:union /union all

语句:(select colum1,colum2…columN from tableA ) union (select colum1,colum2…columN from tableB )

         或 (select colum1,colum2…columN from tableA ) union all (select colum1,colum2…columN from tableB );

union语句注意事项:

         1.通过union连接的SQL它们分别单独取出的列数必须相同;

         2.不要求合并的表列名称相同时,以第一个sql 表列名为准;

         3.使用union 时,完全相等的行,将会被合并,由于合并比较耗时,一般不直接使用 union 进行合并,而是通常采用union all 进行合并;

         4.被union 连接的sql 子句,单个子句中不用写order by ,因为不会有排序的效果。但可以对最终的结果集进行排序;

           (select id,name from A order by id) union all (select id,name from B order by id); //没有排序效果

           (select id,name from A ) union all (select id,name from B ) order by id; //有排序效果

案例解释:将a表和b表合并,表结构如下:

Mysql—— 内连接、左连接、右连接以及全连接查询          Mysql—— 内连接、左连接、右连接以及全连接查询

采用 union 全连接:

Mysql—— 内连接、左连接、右连接以及全连接查询

union会自动将完全重复的数据去除掉,a、b表中”c”的值都为15,所以只显示一行。

采用 union all 全连接:

Mysql—— 内连接、左连接、右连接以及全连接查询

union all会保留那些重复的数据;

左右连接练习题:

根据给出的表结构按要求写出SQL语句。t 表(即Team表)和 m 表(即Match表) 的结构如下:

Mysql—— 内连接、左连接、右连接以及全连接查询     Mysql—— 内连接、左连接、右连接以及全连接查询

t 表(即Team表)和 m 表(即Match表) 的内容如下:

Mysql—— 内连接、左连接、右连接以及全连接查询         Mysql—— 内连接、左连接、右连接以及全连接查询

t 表和 m 表下载地址

m 表(即Match表) 的 hostTeamID 与 guestTeamID 都与 t 表(即Team表) 中的 teamID 关联。请查出 2006-6-1 到2006-7-1之间举行的所有比赛,并且用以下形式列出: 拜仁   2:0  不来梅  2006-6-21

===============================================================================

解决方案:

第一步:先以 m 表左连接 t 表,查出 m 表中 hid 这列对应的比赛信息:

SELECT m.mid,t.tname,m.mres,m.matime as time FROM m LEFT JOIN t ON t.tid = m.hid;

查询结果记为结果集 t1 ,t1 表如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

第二步:先以 m 表左连接 t 表,查出 m 表中 gid 这列对应的比赛信息:

SELECT m.mid,t.tname,m.mres,m.matime FROM m LEFT JOIN t ON t.tid = m.gid;

查询结果记为结果集 t2 ,t2 表如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

第三步:以结果集 t1 为基础左连接查询结果集 t2,查询条件为两者比赛序号(mid)相同。

SELECT t1.tname,t1.mres,t2.tname,t1.time FROM 
(SELECT m.mid,t.tname,m.mres,m.matime as time FROM m LEFT JOIN t ON t.tid = m.hid) 
as t1 
LEFT JOIN 
(SELECT m.mid,t.tname,m.mres,m.matime as time FROM m LEFT JOIN t ON t.tid = m.gid) 
as t2 
ON t1.mid = t2.mid WHERE t1.time BETWEEN '2006-06-01' AND '2006-07-01';

查询结果如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

全连接练习题:

A表和B表结构如下,请将两表合并:

Mysql—— 内连接、左连接、右连接以及全连接查询            Mysql—— 内连接、左连接、右连接以及全连接查询

合并要求:A表中a:5,B表中a:5,因此合并后表中a对应的值为10;要求查出的结果样本如下:

Mysql—— 内连接、左连接、右连接以及全连接查询

采用 union all 全连接,然后使用from 子查询:

SELECT id,SUM(num) as num FROM ((SELECT id,num FROM a) UNION ALL(SELECT id,num FROM b)) as tb GROUP BY id;

Mysql—— 内连接、左连接、右连接以及全连接查询

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/129955.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • kettle工具的介绍和使用

    kettle工具的介绍和使用kettle详解(数据抽取、转换、装载)原文地址链接:https://blog.csdn.net/qq_35731570/article/details/71123413文件资源库模式的调度命令:job:$kitchen路径-file=$job路径kitchen.sh-file=/opt/dpbs/kettlefile/pan_quality_indicator….

    2022年10月16日
    4
  • python ==和is_python中is是什么意思

    python ==和is_python中is是什么意思前置知识点当我们创建一个对象时,我们要知道它内部干了些什么1.创建了一个随机id,开辟了一片内存地址2.自动声明了这个对象的类型type3.给这个对象赋值value小例子a=1pri

    2022年7月29日
    8
  • YUV图像合成原理[通俗易懂]

    YUV图像合成原理[通俗易懂]YUV图像合成原理引言:在视频监控中最常用的就是图像拼接和字符叠加,25FPS的视频流,如果每隔40MS就从各个通道中取一幅图像来合成,则可以看到一个实时的合成视频。合成的过程也就是原始图像的拼接、缩放的过程,本文主要阐述UV分开存储的YUV420图像拼接的过程,实现下图的效果。一、原图图像格式1、图像常用的格式有两种RGB和YUV(1)YUV是

    2022年7月16日
    16
  • robotium 代码

    robotium 代码Robotium之用例分析    http://blog.csdn.net/wirelessqa/article/details/7847466robotium各种方法:http://wenku.baidu.com/link?url=XoPtudf4lgpyzhbLPGJ-6ie8VM2hcCb4Gl6rHozgOrgxWfK52nj-kHzhFbZDkoc_FASztmmPG

    2022年7月25日
    12
  • DropDownList绑定数据库「建议收藏」

    DropDownList绑定数据库「建议收藏」//获取文本this.DropDownList1.SelectedItem.Text;本类内使用protectedvoidPage_Load(objectsender,EventArgse)   {       this.DropDownList1.Items.Clear();       this.DropDownList1.DataSource=DbHelperSQL.Query(“select*fromauthors”).Tables[0];       this.Drop

    2022年10月8日
    3
  • 进程调度与进程切换_模式切换和进程切换有什么区别

    进程调度与进程切换_模式切换和进程切换有什么区别从今天开始,我们将要开启一个新的系列【闪耀计划】,没错!这是今年上半年的一整个系列计划!本专题目的是通过百天刷题计划,通过题目和知识点串联的方式,完成对计算机操作系统的复习和巩固;同时还配有专门的笔记总结和文档教程哦!想要搞定,搞透计算机操作系统的同学,本专栏将会通过模块化的分类,刷够1000道题,为大家提供点对点的考点相关知识轰炸!值得注意的是,本专栏将会通过教程+课后习题的方式来进行巩固教学,课后习题的题量也是算入总题数的哦!

    2022年10月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号