MySQL:两表取交集、并集、差集「建议收藏」

MySQL:两表取交集、并集、差集「建议收藏」创建两个表:CREATETABLEa_student(idINTNOTNULLPRIMARYKEYAUTO_INCREMENTCOMMENT'主键',sno

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

创建两个表:

CREATE TABLE a_student(
  id INT NOT NULL PRIMARY KEY AUTO_INCREMENT COMMENT ‘主键’,
  sno VARCHAR(20) NOT NULL COMMENT ‘学号’,
  sname VARCHAR(20) NOT NULL COMMENT ‘性名’,
  sex TINYINT NOT NULL COMMENT ‘性别 1:男,2:女’,
  sage int COMMENT ‘年龄’,
  CREATE_time datetime DEFAULT NULL COMMENT ‘创建时间’,
  test_time datetime COMMENT ‘测试时间’,
  UPDATE_time datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT ‘更新时间’
);

CREATE TABLE b_student(
  id INT NOT NULL PRIMARY KEY AUTO_INCREMENT COMMENT ‘主键’,
  sno VARCHAR(20) NOT NULL COMMENT ‘学号’,
  sname VARCHAR(20) NOT NULL COMMENT ‘性名’,
  sex TINYINT NOT NULL COMMENT ‘性别 1:男,2:女’

);

 添加数据:

a_student:

MySQL:两表取交集、并集、差集「建议收藏」

 b_student:

 MySQL:两表取交集、并集、差集「建议收藏」

查询并集UNION ALL

例1:两表字段相同

SELECT sno,sname FROM a_student
UNION ALL
SELECT sno,sname FROM b_student
MySQL:两表取交集、并集、差集「建议收藏」

例2:两表字段不同

SELECT sno,sname FROM a_student
UNION ALL
SELECT sno,sex FROM b_student

 MySQL:两表取交集、并集、差集「建议收藏」

例3:两表字段数量不一样

SELECT * FROM a_student  UNION ALL
SELECT sno,sname FROM b_student

MySQL:两表取交集、并集、差集「建议收藏」

 例4:两表字段数量不一样

SELECT sno,sname FROM a_stunt
UNION ALL
SELECT sno FROM b_student

MySQL:两表取交集、并集、差集「建议收藏」

 查询并集UNION 

 例1:两表字段不同

SELECT sno,sname FROM a_student
UNION
SELECT sno,sex FROM b_student

MySQL:两表取交集、并集、差集「建议收藏」

结果不明显,新增数据:

a_student:

MySQL:两表取交集、并集、差集「建议收藏」

 例2:两表字段相同,且有重复数据(UNION ALL)

SELECT sno,sname FROM a_student
UNION ALL
SELECT sno,sname FROM b_student

 MySQL:两表取交集、并集、差集「建议收藏」

  例3:两表字段相同,且有重复数据(UNION)

SELECT sno,sname FROM a_student
UNION
SELECT sno,sex FROM b_student

 MySQL:两表取交集、并集、差集「建议收藏」

 总结:去重去的是完全相同的数据,指查询的两个字段值都相同

 

交集INNER JOIN

— INNER JOIN (等值连接) 只返回两个表中联结字段相等的行
— inner join并不以谁为基础,它只显示符合条件的记录.

例1:以a表为主表

SELECT a.*
FROM a_student a
INNER JOIN b_student b
ON a.id=b.id AND a.sname=b.sname;

MySQL:两表取交集、并集、差集「建议收藏」

 例2:以b表为主表

— USING(id,name) 等价于 on后面的条件
SELECT b.* FROM a_student a
INNER JOIN b_student b USING(id,sname)

MySQL:两表取交集、并集、差集「建议收藏」

 

差集:

例1:a-b

SELECT a.*
FROM
a_student a
LEFT JOIN b_student b
ON a.id=b.id AND a.sname=b.sname
WHERE b.id IS NULL

MySQL:两表取交集、并集、差集「建议收藏」

 

 例2:b-a

SELECT b.*
FROM
a_student a
RIGHT JOIN b_student b
ON a.id=b.id AND a.sname=b.sname
WHERE a.id IS NULL

MySQL:两表取交集、并集、差集「建议收藏」

 

补充:

单纯的外连接

例1:右外连接

MySQL:两表取交集、并集、差集「建议收藏」

 

SELECT *
FROM
a_student a
RIGHT JOIN b_student b
ON a.id=b.id AND a.sname=b.sname

MySQL:两表取交集、并集、差集「建议收藏」

 

例2:左外连接

MySQL:两表取交集、并集、差集「建议收藏」

 

SELECT *
FROM
a_student a
LEFT JOIN b_student b
ON a.id=b.id AND a.sname=b.sname

MySQL:两表取交集、并集、差集「建议收藏」

 

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

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

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


相关推荐

  • raid0和raid1的区别

    raid0和raid1的区别RAID是英文RedundantArrayofIndependentDisks的缩写,中文简称为独立冗余磁盘阵列。简单的说,RAID是一种把多块独立的硬盘(物理硬盘)按不同的方式组合起来形成一个硬盘组(逻辑硬盘),从而提供比单个硬盘更高的存储性能和提供数据备份技术。组成磁盘阵列的不同方式称为RAID级别(RAIDLevels)。集中管理思想:资源整合,用统一标准进行管理它们共同点…

    2022年7月15日
    19
  • Java获取二维数组行列长度「建议收藏」

    Java获取二维数组行列长度「建议收藏」二维数组intarray[][]=newint[3][3];行长度:array.length列长度:array[i].lengthclassTest{for(inti=0;i

    2022年5月12日
    51
  • phpstorm2021.12永久激活码【2021最新】

    (phpstorm2021.12永久激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月30日
    418
  • 国内CMS技术发展的外在表现形式「建议收藏」

    国内CMS技术发展的外在表现形式「建议收藏」网站作为企事业单位的网上名片已经成为必需。大多数单位都选择利用成熟的CMS(内容管理系统)交给专业的公司或者本单位负责人(相当于站长)建设自己的网站。国内CMS技术的不断发展的外在表现,以便站长和建站公司选择合适的CMS系统建设更强大的网站。我建站时用过很多CMS系统,各有各的特点。现在之所以选择主要用We7的CMS是觉得在以下方面还是不错的。一产品成熟度。据我了解We7CMS系统

    2022年5月18日
    37
  • hostapd配置

    hostapd配置我们有个闲置的USB无线适配器(WIFI适配器),而我们的ISP路由器却是有线的。怎样把我们的家庭NAS服务器变成无线访问点(WAP),在不用买额外的WPA盒子的情况下,在Debian或Ubuntu系统下使用无线设备访问到它?你需要使用hostapd作为访问点和认证服务器。它实现了IEEE802.11访问点管理,IEEE802.1X/WPA/WPA2/EAP授权,RADIUS客户端,…

    2022年5月21日
    220
  • GoLand 2021.7.20 x64 激活码(注册激活)

    (GoLand 2021.7.20 x64 激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月21日
    47

发表回复

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

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