SQL几种查询

几种表的查询

  1. 自连接查询
    在一张表中,单纯地使用select语句并加上where条件进行查询,得到的只是列与列之间存在的关系
    例如此表:
    在这里插入图片描述
    查询语句:select 本月,累计 from test where 本月>累计
    得到如下图的查询结果
    在这里插入图片描述
    可是,如果我们想要查询当累计数值都为负数时,本月数据不相等的两个地区有多少种可能,这要怎么查询?显然单纯地使用select是无法解决的,因为这个查询问题已经涉及到了列中数据与数据之间的关系
    查询语句:select first.地区 second.地区 from data_fu first,data_fu second where first.本月>second.本月 and first.累计<0 and second.累计<0

自连接的另一个例子:
现有如下的一个表(列车车次和停靠站点):
在这里插入图片描述
先要查询出某一线路的火车可以联通的任意两个城市的名称
查询语句:select first.num,first.stop as start,second.stop as end from route first,route second where first.num=second.num and first.stop!=second.stop;
查询结果:
在这里插入图片描述


  1. 交叉连接(cross join)
    交叉连接的效果就是两个表的广义笛卡尔积
    查询语句:select s.* , teacher_name from student_table s cross join teacher_table t

  1. 自然连接(natural join)
    给定关系R和关系S,自然连接由R和S的笛卡尔积中选取相同属性组B上值相等的元素构成(自然连接会以两个表中的同名列作为连接条件;如果两个表中没有同名列,则自然连接和交叉连接效果完全一样)
    现有两个表:在这里插入图片描述

查询语句:select R.*,S.* from R natural join S
查询结果:
在这里插入图片描述


  1. using连接
    与自然连接类似,都是以两笔中的同名列作为连接条件,但是,区别在于,若两表中有多个同名列,使用using子句可以显式指定以哪个同名列作为连接条件
    查询语句:select s.*,teacher_name from student_table s join teacher_table t using(teacher_id)

  1. on连接
    可以替代用where引出的等值连接和非等值连接
    查询语句:select s.*,teacher_name from student_table s join teacher_table t on s.java_teacher=t.teacher_i

  1. 左外连接和右外连接
    左外连接:用左表的数据去匹配右表,不符合条件的数据用NULL代替
    例如:有如下两表:
    在这里插入图片描述
    在这里插入图片描述

左外连接:
查询语句:select s.*,teacher_name from student s left join teacher t on s.java_teacher>t.teacher_id;
查询结果:
在这里插入图片描述
这里用s表匹配t表,(一共会匹配10次,结果会剔除重复的数据),当左表无法与右表成功匹配时,保留左表中的数据,补null

右外连接:与左外连接相反
查询语句select s.*,teacher_name from student s right join teacher t on s.java_teacher<t.teacher_id;
查询结果:
在这里插入图片描述
右表数据保留,补null
<左外连接,结果里必须有左表里的全部数据,右外连接相反>

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL语句中,常见的几种JOIN操作包括INNER JOIN、LEFT JOIN、RIGHT JOIN以及FULL JOIN。它们的区别如下: INNER JOIN:内连接是基于两个表之间的共同值进行匹配,返回两个表中满足连接条件的交集。这意味着只有在两个表中都存在的匹配行才会被返回。 LEFT JOIN:左连接返回左表中的所有行,以及与右表中匹配的行。如果在右表中没有匹配的行,则以NULL填充右侧的列。 RIGHT JOIN:右连接返回右表中的所有行,以及与左表中匹配的行。如果在左表中没有匹配的行,则以NULL填充左侧的列。 FULL JOIN:全连接是左连接和右连接的组合,返回左表和右表的并集。对于没有匹配的记录,将使用NULL表示。 需要注意的是,在MySQL中,并不直接支持FULL JOIN操作。可以使用左连接和右连接的合集来实现FULL JOIN的效果。 综上所述,INNER JOIN返回两个表的交集,LEFT JOIN返回左表和右表的交集以及左表中没有匹配的行,RIGHT JOIN返回左表和右表的交集以及右表中没有匹配的行,FULL JOIN返回左表和右表的并集,并包含所有的匹配和未匹配的行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [一起学习SQL中各种join以及它们的区别](https://blog.csdn.net/qq_41153943/article/details/125565202)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值