数据库Join查询:内联、左外联、右外联、取交集

数据库Join查询:内联、左外联、右外联、取交集,第1张

原文: RelaxHeart网 - Tec博客: 库Join查询:内联、左外联、右外联、取交集

示例:

在MySQL创建两张表:a_table、b_table

随便插入几条数据:

组合两个表中的记录,返回关联字段相符的记录,也就是两个表的交集

left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。

左表全部记录都会显示出来,右表只显示出满足条件的记录,不足的列全部显示NULL

right join 是 right outer join的简写,它的全程是右外连接,是外链接的一种。

右表全部记录都会显示出来,左表只显示满足条件的记录,不足的列全部显示NULL

有了内联、外联查询,有没有取并集查询呢?当然也有了:

注意:查询报错了!!!

左外查询 union 右外查询

UNION定义:UNION *** 作符用于合并两个或多个 SELECT 语句的结果集。

注意:

UNION 和 UNION ALL 区别:UNION ALL会列出所有结果,有重复,UNION没有重复

inner join: 如果查询的表中都有至少一个匹配,则返回行

left join: 即使右表中没有匹配,也从左表返回所有的行

right join: 即使左表中没有匹配,也从右表返回所有的行

full join: 只要其中一个表中存在匹配,就返回行,但是在mysql中不支持

union:合并多个查询语句的结果集(去重)

union all:合并多个查询语句的结果集(不去重)

更多文章: RelaxHeart网更多博文

SQL集合运算:差集、交集、并集

2011年03月30日 15:41:00

阅读数:15446

1、差集( except )

select a from t_a

except

select a from t_b

-- 也可写作:

select a from t_a where a not in (select a from t_b)

-- 多个字段时:

select a,b from t_a

except

select a,b from t_b

-- 多字段的查集也可写成:

select a,b from t_a where (a,b) not in (select a,b from t_b)

2、交集( intersect )

select a from t_a

intersect

select a from t_b

-- 也可写作:

   select a from t_a where a in (select a from t_b)

3、并集( union )

select a from t_a

union distinct

select a from t_b


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6881670.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-29
下一篇 2023-03-29

发表评论

登录后才能评论

评论列表(0条)

保存