0

0

MySQL left join 左连接详解介绍

php中文网

php中文网

发布时间:2016-06-07 17:52:09

|

2332人浏览过

|

来源于php中文网

原创

LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。left join 左连接——以左边的数据表为基准,若右边的数据表没有对应的数据则显示空白

表a


1 aid adate  

2 1 a1  

3 2 a2  

4 3 a3
表b


1 bid bdate  

2 1 b1  

3 2 b2  

4 4 b4


1

 代码如下 复制代码
select * from a left join b on a.aid = b.bid

首先取出a表中所有数据,然后再加上与a、b匹配的的数据。

此时的取出的是:


1 1 a1 b1  

2 2 a2 b2  

3 3 a3 空字符
同样的也有right join

指的是首先取出b表中所有数据,然后再加上与a、b匹配的的数据。

此时的取出的是:


1 1 a1 b1  

2 2 a2 b2  

left join性能


1例子

 代码如下 复制代码

select  distinct count('goods_id') as num , g.goods_id,g.goods_name from ms_goods as g left  join ms_order_goods as og on g.goods_id = og.goods_id group by goods_id

显示行 0 - 29 (1,475 总计, 查询花费 0.0167 秒)

2例子

 代码如下 复制代码

select  distinct count('goods_id') as num , g.goods_id,g.goods_name from ms_goods as g , ms_order_goods as og where g.goods_id = og.goods_id group by goods_id

显示行 0 - 29 (257 总计, 查询花费 0.0088 秒)

实例


表结构如下:

MDate      StoreCode  GoodsCode  ToStoreCode  GoodsAmount  GoodsFlag
2005-12-12   001             101                  888                         2            3
2005-12-13   001             101                     3                          1
2005-12-15   001             101                     1                          2

三条记录的意思分别为:
2005-12-12从001移到888  2件        
2005-12-13从001销售     3件
2005-12-15仓店001进货   2件

出报表
StoreCode  GoodsCode  StockAmount   InAmount     OutAmount    SellAmount
001              101                       3                  0                      2             1
注:StockAmount进货数量   InAmount移入数量     OutAmount移出数量    SellAmount销售数量

 代码如下 复制代码

select
    StoreCode,
    GoodsCode,
    StockAmount = sum(case GoodsFlag when 2 then GoodsAmount else 0 end),
    InAmount    = sum(case GoodsFlag when 4 then GoodsAmount else 0 end),
    OutAmount   = sum(case GoodsFlag when 3 then GoodsAmount else 0 end),
    SellAmount  = sum(case GoodsFlag when 1 then GoodsAmount else 0 end)
from
    表
group by
    StoreCode,GoodsCode

例子3
po_order_det 表
ID   MA_ID     QTY
01   #21钢     30 
02   #22钢     40
03   #23铝     30

ST_CONVER 表
ID  QTY
01  20
02  10
要求返回集 QTY = po_order_det.QTY - ST_CONVER.QTY AND po_order_det.ID=ST_CONVER.ID

ID     MA_ID   QTY
01     #21钢   10
02     #22钢   30
03     #23铝    30

 代码如下 复制代码

select a.order_id,a.id,a.ma_id,a.qty,isnull(b.qty,0) qtyy, isnull(a.qty  - b.qty ,0) qtyx
from po_order_det a left join st_conver b
on a.id=b.id and a.filid=b.filid
and a.id=b.id and a.order_id=b.order_id
Where  a.filid='S'

总结

北极象沉浸式AI翻译
北极象沉浸式AI翻译

免费的北极象沉浸式AI翻译 - 带您走进沉浸式AI的双语对照体验

下载

SQL 中只出现一个左连接:

 代码如下 复制代码

 select a.*, b.*, c.* from b, a

left join c on a.id = c.id

where b.id = a.iid

 注意 表a 要和最近的一个关联的leftjoin挨着。

 SQL中出现了2个或者多个左连接:

 

 代码如下 复制代码

select a.*, b.* c.*, d.*, e.*

from ((

   c, b, a

)

   left join d on d.id = a.id

)  left join e  on e.id = b.id

 

where c.id = b.id

and b.id = a.id

 

leftjoin总和最近的一个表挨着,同时需要用借助于括号

相关专题

更多
javascript void运算符
javascript void运算符

void是一元运算符,执行右侧表达式但始终返回undefined;用于丢弃返回值、阻止a标签跳转、IIFE忽略结果、动态导入不取Promise、安全获取undefined。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

vscode的界面字体大小调整
vscode的界面字体大小调整

调整VSCode界面字体大小可通过设置编辑器或整体UI缩放实现;2.修改"Editor:FontSize"改变代码字体;3.设置"Window:ZoomLevel"调整整体界面字体;4.使用Ctrl+滚轮快捷键临时缩放。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

VSCode的注释快捷键
VSCode的注释快捷键

单行注释快捷键为Ctrl+/(Windows/Linux)或Cmd+/(macOS),块注释使用Shift+Alt+A(Windows/Linux)或Shift+Option+A(macOS),VSCode会根据语言类型自动匹配语法,如JavaScript用//,Python用#,C++用//,若快捷键无效需检查语言扩展或插件冲突。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

Golang 命令行工具(CLI)开发实战
Golang 命令行工具(CLI)开发实战

本专题系统讲解 Golang 在命令行工具(CLI)开发中的实战应用,内容涵盖参数解析、子命令设计、配置文件读取、日志输出、错误处理、跨平台编译以及常用CLI库(如 Cobra、Viper)的使用方法。通过完整案例,帮助学习者掌握 使用 Go 构建专业级命令行工具与开发辅助程序的能力。

4

2025.12.29

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

165

2025.12.26

压缩文件加密教程汇总
压缩文件加密教程汇总

本专题整合了压缩文件加密教程,阅读专题下面的文章了解更多详细教程。

56

2025.12.26

wifi无ip分配
wifi无ip分配

本专题整合了wifi无ip分配相关教程,阅读专题下面的文章了解更多详细教程。

108

2025.12.26

漫蛙漫画入口网址
漫蛙漫画入口网址

本专题整合了漫蛙入口网址大全,阅读下面的文章领取更多入口。

356

2025.12.26

b站看视频入口合集
b站看视频入口合集

本专题整合了b站哔哩哔哩相关入口合集,阅读下面的文章查看更多入口。

703

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 776人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号