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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 源码免杀教程 源码免杀思路详解

    绝对不一样的源码免杀教程!绝对不一样的免杀实战体验!清晰的思路!细致全面的思路详解!让你感到免杀原来可以这么简单!教你如何在源代码中找出被杀代码,修改代码从而达到免杀效果!免杀之-网络攻防入门书籍推荐《精通黑客免杀》一部关于黑客免杀技术的书籍,学习各种免杀,躲避杀毒软件的追杀,为自己的马放下一道赦免令。目前国内关于黑客免杀技术的书籍应该很少的,大致可以说是没有。在本书中所介绍的启发式扫描免杀…

    2022年4月4日
    360
  • 【电子书下载】《Android应用程序开发与典型案例》完整版!!

    【电子书下载】《Android应用程序开发与典型案例》完整版!!图书简介:《android应用程序开发与典型案例》共23章,内容包含两大部分。第一部分是android程序设计基础,在介绍android环境搭建以及android系统基本控件和组件后,详细介绍了android系统应用编程中典型的技术,比如,android中的图形图像、多媒体编程、gps定位与地图编程等;第二部分是android程序ui设计,从手机软件的交互设计谈起,介绍了android用户界面

    2022年6月29日
    22
  • UOJ#373. 【ZJOI2018】线图 搜索,树哈希,动态规划

    UOJ#373. 【ZJOI2018】线图 搜索,树哈希,动态规划原文链接www.cnblogs.com/zhouzhendong/p/UOJ373.html前言真是一道毒瘤题。UOJ卡常毒瘤++。我卡了1.5h的常数才过QAQOrzjry标算居然是指数做法

    2022年8月5日
    3
  • 左移(1_右移一位

    左移(1_右移一位今天在书上看到一段代码:http.Server{Addr:"8080"……MaxHeaderBytes:1<<20}知道1<<20是左移的意思,但就是

    2022年8月5日
    1
  • shell-2.shell定义变量

    shell-2.shell定义变量

    2021年9月14日
    49
  • Pubmedy加载时显示程序包无效的解决方案[通俗易懂]

    目前谷歌应用商城已经下架Pubmedy,本地安装又遇到程序包无效:“CRX_HEADER_INVALID”。解决方案:将PubMedy.crx重命名为PubMedy.rar解压到要安装的位置找到扩展程序选项,并启用开发者选项选择加载已解压的扩展程序5.选择解压目录可以看到已经安装完毕…

    2022年4月9日
    93

发表回复

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

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