SQL Sever联接查询

简介: 作者主页:https://www.couragesteak.com/

联接查询:是有一个笛卡尔乘积运算再加一个选取运算构成的查询。
首先用笛卡尔乘积完成对两个数据集合的乘运算,然后对生成的结果集合进行选取运算,确保只把分别来自两个数据集合并且具有重叠部分的行合并在一起。
联接的全部意义在于水平方向上合并两个数据集合,并产生一盒新的结果集合。
联接可分为以下几类:内部联接、外部联接、交叉联接

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

1. 内部联接

内部联接是使用比较运算符比较要联接列中的值得联接。内连接也叫联接,最早被称为普通联接或自然联接。
内联接是从结果中删除其他被联接表中没有匹配行的所有行,所以内联接可能会丢失信息。

select * from SC
join Student
on Student.Sno = SC.Sno

在这里插入图片描述

2. 外部联接

外部联接则扩充了内联接的功能,会吧内联接中删除表源中的一些保留下来,由于保留下来的行不同,可将外部联接分为 左向外部联接右向外部联接完整外部联接

2.1 左向外联接

语法

select fieidlist from table1 
left join table2
on table1.comlumnn=table2.column

参数说明:

参数 说明
fieldlist 搜索条件
table1 [inner] join table2 将table1表与table2表进行外部联接
table1.column=table2.column table1表中与table2表中相同的列

eg. 把Studnet表和SC表左外连接,第二个表SC有不满足联接条件的行,则用NULL表示 。

select * from Student
left join SC
on Student.Sno=SC.Sno

在这里插入图片描述
解析:这里出现NULL说明SC表中没有Sno等于4和6的

2.2 右向外联接

右外向联接使用 right jion 进行联接,是左向外联接的反向联接。将返回右表的所有行。如果右表的某一行在左表中没有匹配行,则将为坐标返回空值。

语法:

select fieldlist from table1 
right join table2
on table1.column=table2.column

eg. 把SC表和Course表右外联接,第一个表SC有不满足联接条件的行,则用NULL表示。

select * from SC
right join Course
on Course.Cno=SC.Cno

这里右外联接的是Course表,所以Course表的数据完整
在这里插入图片描述

2.3 完整外联接

完整外连接使用 full join 进行联接,将返回左表和右表中的所有行。当某一行在另一个表中没有匹配时,另一个表的选择列表将包含空值。如果表之间有匹配行,则将整个结果集行包含基表的数据值。

语法:

select fieldlistfrom table1 
full join table2
on table1.column=table2.column

eg. 把SC表和Course表完整外部联接,显示两个表中所有的行。

select * from SC
full join Course
on Course.Cno=SC.Cno

在这里插入图片描述

3. 交叉联接

交叉联接使用 cross join 进行联接,没有where子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集得大小。

交叉联接中列和行的数量是这样计算的:

  • 交叉联接中的列=原表中列的数量总和(想加)。
  • 交叉联接中的行=原表中行数的积(相乘)。

    语法:

select fieldlist from table1
cross join table2

其中,忽略 on 方法来创建交叉联接。

eg. 把 Student 表和 Course 表进行交叉联接。

select * from Student
cross join Course

在这里插入图片描述

4. 联接多表

4.1 在where子句中联接多表

在 from 子句中写联接多个表的名称,然后将任意两个表的联接条件分别写在 where 子句后。

语法:

select fieldlist from table1, table2, table3 ...
where table1.column=table2.column
and table2.column=table3.column and ...

eg. 把 Student 表、Course 表和 SC 表,这3个表在 where 子句中联接。

select * from Student,Course,SC
where Student.Sno=SC.Sno
and SC.Cno=Course.Cno

在这里插入图片描述

4.2 在 from 子句中联接多表

在 from 子句中联接多个表示内部联接的扩展。
语法:

select fieldlist from table1
join table2
join table3...
on table1.column=table2.column
and tbale2.column=table3.column

eg. 把 Student表、Course表 和 SC表,这3个表在from子句中联接。

select * from Student
join SC
join Course
on SC.Sno=Course.Cno
on Student.Sno=SC.Sno

在这里插入图片描述

5. 使用 case 函数进行查询

case 函数用于计算条件列表并返回多个可能结果表达式之一。
case函数具有以下两种格式:

  • 简单case函数将某个表达式与一组简单表达式进行比较以确定结果。
  • case搜索函数计算一组不二表达式以确定结果。

简单 case 函数的语法如下:

case input_expression
    when when_expression then result_expression
    [...n]
    [
    else else_result_expression
    ]
end

case 搜索函数的语法如下:

case
    when Boolean_expression then result_expression
    [...n]
    [
    else else_result_expression
    ]
end

在 select 语句中,简单 case 函数仅检查是否相等,而不进行其他比较。本实例使用 case 函数更改产品系列类别的显示,以使这些类别更容易理解。

select ProductNumber, Category = 
    case productLine
        when 'R' then 'Rpad'
        when 'M' then 'Mountain'
        when 'T' then 'Touring'
        when 'S' then 'Other sale items'
        else 'Not for sale'
    end
  Name
from Production.Product
order by ProductNumber

eg. 查询SC表中的Sno和Cno,如果分数 >=90为优秀,>=80为良好

select Sno,Cno,等级=case 
when Grade >=90 then '优秀'
when Grade >=80 then '良好'
else '不及格'
end
from SC

在这里插入图片描述

使用 case 语句更新

使用 case 语句更新学生信息,使所有男生年龄减 1 ,所有女生年龄加 1 ,

update Student
set Sage=
case when Sex='男' then Sage-1
when Sex = '女' then Sage+1
end

在这里插入图片描述
官方地址:
https://www.920vip.net/article/87

相关文章
|
10天前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
22天前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
75 10
|
16天前
|
SQL 关系型数据库 MySQL
|
29天前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
1月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
1月前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
98 5
|
25天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
31 0
|
1月前
|
SQL 数据可视化 BI
SQL语句及查询结果解析:技巧与方法
在数据库管理和数据分析中,SQL语句扮演着至关重要的角色
|
1月前
|
SQL 监控 关系型数据库
使用SQL语句查询操作耗时的技巧与方法
在数据库管理和优化过程中,了解SQL查询操作的耗时是至关重要的
|
1月前
|
SQL
创建分组总计查询的SQL技巧与方法
在SQL中,创建分组总计查询(也称为聚合查询)是一项非常基础且重要的技能
下一篇
无影云桌面