首页 > 数据库 >【SQL】所谓的连表查询

【SQL】所谓的连表查询

时间:2023-08-28 21:56:45浏览次数:31  
标签:Customers 01 Orders 查询 连表 对应 SQL null 连接

连表查询

外连接

外连接分为两种,左(外)连接右(外)连接

基本语法如下:

SELECT 字段列表
FROM 表1
LEFT JOIN 表2
ON 条件;

这是左连接,因此以表1中的 [字段列表] 为基础,拿着这些字段去表2一条一条的找,看看有没有符合 [条件] 的,没有找到符合条件的用null代替,然后把表1与表2中的满足条件的和不满足条件的(null)拼在一起,返回结果

右连接也类似

SELECT 字段列表
FROM 表1
RIGHT JOIN 表2
ON 条件;

这是右连接,因此以表2中的 [字段列表] 为基础,拿着这些字段去表1一条一条的找,看看有没有符合 [条件] 的,没有找到符合条件的用null代替,然后把表1与表2中的满足条件的和不满足条件的(null)拼在一起,返回结果

说白了就是基于某个表的数据去另一个表查找满足条件的数据,如果查到就返回值,查不到就用null代替返回值

下面是例子

先看左连接,我们使用表1去表2中查询

酸菜在表2中没有对应,好,酸菜对应null;

肉末在表2中uid与茄子对应,肉末对应茄子;

可乐在表2中uid与鸡翅对应,可乐对应鸡翅;(拼在一起返回结果)

注意,左连接时以表1为基础,表1遍历完之后就结束了,因此不会存在"null-猪蹄"的情况

再看右连接,这里使用表2去表1中查询

茄子在表1中uid与对应肉末,茄子对应肉末;

鸡翅在表1中uid与对应可乐,鸡翅对应可乐;

猪蹄的uid在表1中无对应,那么其uid对应null,其aname也对应null;

因为是右连接,以表2为基础,所以不会有酸菜出现

内连接

简单来说,内连接就是使用关键字INNER JOIN将两个表连接起来,查询出所有的结果

例如:

SELECT *
FROM 表1
INNER JOIN 表2;

如果此时就输出,那么mysql会使用笛卡尔积将两张表进行组合并返回结果

笛卡尔积是指将第一个表的每一行与第二个表的每一行都进行组合,生成一个新的结果集。

假设我们有两个表:Customers(客户表)和 Orders(订单表)。每个表都有几行记录。

Customers 表:

| CustomerID | CustomerName |
|------------|--------------|
| 1          | Alice        |
| 2          | Bob          |

Orders 表:

| OrderID | OrderDate   |
|---------|-------------|
| 101     | 2022-01-01  |
| 102     | 2022-02-01  |

如果我们执行下面的查询语句而没有指定连接条件:(这里隐式的写了内连接

SELECT Customers.CustomerName, Orders.OrderID, Orders.OrderDate
FROM Customers, Orders;

则会得到如下结果:

| CustomerName | OrderID | OrderDate   |
|--------------|---------|-------------|
| Alice        | 101     | 2022-01-01  |
| Alice        | 102     | 2022-02-01  |
| Bob          | 101     | 2022-01-01  |
| Bob          | 102     | 2022-02-01  |

这个结果是通过将 Customers 表中的每一行都与 Orders 表中的每一行进行组合得到的。结果集中的每一行都包含了 Customers 表和 Orders 表中的所有列值。

但是,笛卡尔积会导致结果集的大小呈指数级增长,并且可能会产生大量冗余数据。因此,在实际应用中,我们通常会根据特定的连接条件来执行连接操作,以避免不必要的笛卡尔积。

于是就有:

SELECT *
FROM 表1
INNER JOIN 表2
ON 条件;

这样我们就可以根据两张表里共同有的一些字段,来过滤想要的数据,从而得到最终结果

注意,如果是隐式的写法,要用WHERE来过滤

先组合,再过滤

标签:Customers,01,Orders,查询,连表,对应,SQL,null,连接
From: https://www.cnblogs.com/DAYceng/p/17663465.html

相关文章

  • 接口查询性能优化-缓存
    查询性能优化缓存种类mybatis一级缓存mybatis二级缓存本地缓存各个节点的数据不同步分布式缓存redis前端h5的缓存本地缓存session缓存mybatis一级缓存一个方法中对同一个sql,查询了多次当在这个方法上加@transactional后续的查......
  • 数据库MySQL
     Concat(a,b)连接a,b两个字段                                    MySQL函数       分组之后再插入查询条件不能用Where关键字,而要用HA......
  • MySQL 分析查询与来源机器
    当前分析针对版本:MariaDB10.5线上出现报错:can'tcreatemorethanmax_prepared_stmt_countstatements。造成这个错误的直接原因就是同时开启了prepare句柄太多导致的,所以比较直接的方式是调大参数,首先查看设置的值:showglobalvariableslike'max_prepared_stmt_count';......
  • SQL SERVER 获取存储过程返回值
    1.OUPUT参数返回值CREATEPROCEDURE[dbo].[nb_order_insert](@o_buyeridint,@o_idbigintOUTPUT)ASBEGINSETNOCOUNTON;BEGININSERTINTO[Order](o_buyerid)VALUES(@o_buyerid)SET@o_id=@@IDENTITYENDEND存储过程中获得方法:......
  • 查询SQL Server数据库执行时间最长的sql语句
    SELECT(total_elapsed_time/execution_count)/1000N'平均时间ms',total_elapsed_time/1000N'总花费时间ms',total_worker_time/1000N'所用的CPU总时间ms',total_physical_readsN'物理读取总次数',total_logical_reads/execution_countN'每次......
  • Arch中使用Qt6的QtSql出现mysql driver not loaded的解决记录
    查阅了网上的说法,出现这个错误的原因大致可能有以下几种:Qt和mysql的位数不一样,一个是32位的,一个是64位的Qt中自带的驱动库与所使用的版本不匹配代码写错了,比如"QMYSQL"写成了"MYSQL"我出现个问题的原因是第二种。参考了一位老哥的博客QTMacM1解决mysqldrivernotloade......
  • MySQL的连接和导出数据分析和lift曲线
    MySQL的连接和使用https://www.cnblogs.com/zdstudy/p/16567399.htmlmysql使用网址https://blog.csdn.net/LikiLyn/article/details/120385981多个文件mergeimportpandasaspdimportnumpyasnpimportpymysql#%%打开数据库连接conn=pymysql.connect(host='地址',user......
  • mysql日志追踪 / 数据恢复
    1.查看日志开启状态showvariableslike'log_%';2.查看日志文件列表showbinarylogs;或者showmasterlogs;3.查看当前日志index位置showmasterstatus;4.查看binlog关键事件showbinlogevents[IN'log_name'][FROMpos][LIMIT[offset,]row_c......
  • ProxySQL简介
    ProxySQL是基于MySQL的一款开源的中间件的产品,是一个灵活的MySQL代理层,可以实现读写分离,支持Query路由功能,支持动态指定某个SQL进行缓存,支持动态加载(无需重启ProxySQL服务),故障切换和一些SQL的过滤功能。多层配置结构disk->是sqlite3数据库,默认位置是$DATADIR/pro......
  • MySQL online DDl原理
    onlineDDL从5.6开始,不阻塞DML但是会阻塞所有的DDL,online有三种模式:INSTANT(8.0.12),INPLACE(rebuild),INPLACE(no-rebuild),具体操作如下:1、只修改表的元数据信息删除二级索引修改索引名(5.7)修改字段名设置(删除)字段的默认值增加varchar长度,如果表示字符串长度的字节数变化则会使用c......