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


相关推荐

  • 骑成一个故事

    骑成一个故事

    2021年7月26日
    125
  • sqlserver不存在或拒绝访问怎么办_sql数据库连接不上

    sqlserver不存在或拒绝访问怎么办_sql数据库连接不上Navicat连接SQLserver数据库时报错:未发现数据源名称并且未指定默认驱动程序导致原因:navicat没有安装sqlserver驱动解决办法:打开Navicat的安装路径,Navicat自带sqlncli_x64.msi,双击安装一下;安装完成之后重启Navicat即可连接成功!…

    2022年10月9日
    2
  • SM4算法设计原理

    SM4算法设计原理SM4分组密码算法描述:SM4分组密码算法是一个迭代分组密码算法,由加解密算法和密钥扩展算法组成。SM4分组密码算法采用非平衡Feistel结构,分组长度为128b密钥长度为128b。加密算法与密钥扩展算法均采用非线性迭代结构。加密运算和解密运算的算法结构相同,解密运算的轮密钥的使用顺序与加密运算相反。密钥及密钥参量:SM4分组密码算法的加密密钥长度为128b,表示为MK=(MK0,M…

    2025年6月10日
    2
  • 如何彻底删除2008数据库_excel批量筛选重复人名

    如何彻底删除2008数据库_excel批量筛选重复人名在企业环境中,对磁盘空间的需求是惊人的。数据备份、文件服务器、软件镜像、虚拟磁盘等都需要占据大量的空间。对此,微软在WindowsServer2012中引入了重复数据删除技术。重复数据删除技术通过

    2022年8月3日
    3
  • evicted Pod

    evicted PodapiVersion:v1kind:Podmetadata:annotations:checksum/config:8476fd6406a3cc87e5471154d85fd7c50e6a629acda16989a09a5d90937bb5b0cni.projectcalico.org/podIP:192.168.1.233/32creationTimestamp:”2019-09-22T06:26:34Z”generateName:test-ap…

    2022年5月13日
    39
  • php 变量名前加一个下划线含义

    php 变量名前加一个下划线含义

    2021年10月21日
    42

发表回复

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

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