创建两个表:

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:


b_student:


查询并集UNION ALL

例1:两表字段相同

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


例2:两表字段不同

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


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

SELECT * FROM a_student UNION ALL
SELECT sno,sname FROM b_student
例4:两表字段数量不一样
SELECT sno,sname FROM a_stunt
UNION ALL
SELECT sno FROM b_student
查询并集UNION
例1:两表字段不同
SELECT sno,sname FROM a_student
UNION
SELECT sno,sex FROM b_student
结果不明显,新增数据:
a_student:
例2:两表字段相同,且有重复数据(UNION ALL)
SELECT sno,sname FROM a_student
UNION ALL
SELECT sno,sname FROM b_student
例3:两表字段相同,且有重复数据(UNION)
SELECT sno,sname FROM a_student
UNION
SELECT sno,sex FROM b_student
总结:去重去的是完全相同的数据,指查询的两个字段值都相同
交集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;
例2:以b表为主表
— USING(id,name) 等价于 on后面的条件
SELECT b.* FROM a_student a
INNER JOIN b_student b USING(id,sname)
差集:
例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
例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
补充:
单纯的外连接:
例1:右外连接
SELECT *
FROM
a_student a
RIGHT JOIN b_student b
ON a.id=b.id AND a.sname=b.sname
例2:左外连接
SELECT *
FROM
a_student a
LEFT JOIN b_student b
ON a.id=b.id AND a.sname=b.sname
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/126649.html