当前位置:网站首页>mysql join技巧
mysql join技巧
2022-07-28 05:24:00 【奇怪的守护神】
笛卡尔积:CROSS JOIN
要理解各种JOIN首先要理解笛卡尔积。笛卡尔积就是将A表的每一条记录与B表的每一条记录强行拼在一起。所以,如果A表有n条记录,B表有m条记录,笛卡尔积产生的结果就会产生n*m条记录。下面的例子,t_blog有10条记录,t_type有5条记录,所有他们俩的笛卡尔积有50条记录。有五种产生笛卡尔积的方式如下。
内连接:INNER JOIN
内连接INNER JOIN是最常用的连接操作。从数学的角度讲就是求两个表的交集,从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录。有INNER JOIN,WHERE(等值连接),STRAIGHT_JOIN,JOIN(省略INNER)四种写法。至于哪种好我会在MySQL的JOIN(二):优化讲述。示例如下。
左连接:LEFT JOIN
左连接LEFT JOIN的含义就是求两个表的交集外加左表剩下的数据。依旧从笛卡尔积的角度讲,就是先从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录(见最后三条)。
右连接:RIGHT JOIN
同理右连接RIGHT JOIN就是求两个表的交集外加右表剩下的数据。再次从笛卡尔积的角度描述,右连接就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上右表中剩余的记录(见最后一条)。
外连接:OUTER JOIN
外连接就是求两个集合的并集。从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录,最后加上右表中剩余的记录。另外MySQL不支持OUTER JOIN,但是我们可以对左连接和右连接的结果做UNION操作来实现。
USING子句
MySQL中连接SQL语句中,ON子句的语法格式为:table1.column_name = table2.column_name。当模式设计对联接表的列采用了相同的命名样式时,就可以使用 USING 语法来简化 ON 语法,格式为:USING(column_name)。
所以,USING的功能相当于ON,区别在于USING指定一个属性名用于连接两个表,而ON指定一个条件。另外,SELECT *时,USING会去除USING指定的列,而ON不会。实例如下。
自然连接:NATURE JOIN
自然连接就是USING子句的简化版,它找出两个表中相同的列作为连接条件进行连接。有左自然连接,右自然连接和普通自然连接之分。在t_blog和t_type示例中,两个表相同的列是id,所以会拿id作为连接条件。
另外千万分清下面三条语句的区别 。
自然连接:SELECT * FROM t_blog NATURAL JOIN t_type;
笛卡尔积:SELECT * FROM t_blog NATURA JOIN t_type;
笛卡尔积:SELECT * FROM t_blog NATURE JOIN t_type;
边栏推荐
- ICC2(三)Clock Tree Synthesis
- EfficientNET_ V1
- TCL and eltcl? Cdnext and CMRL?
- PLC的整体认识
- PT physical aware based on multi voltage
- Learning notes on hardware circuit design 2 -- step-down power circuit
- 4、 Model optimizer and inference engine
- AEM-TESTpro K50和南粤勘察结下的缘分
- Triode design, understanding saturation, linear region and cut-off region
- Selection of PLC
猜你喜欢

Matlab 信号处理

Pycharm2019设置编辑器主题和默认代码

AEM testpro K50 and south Guangdong survey

How can fluke dsx2-5000 and dsx2-8000 modules find the calibration expiration date?

TVS管参数与选型

ICC2(四)Routing and Postroute Optimization

(PHP graduation project) based on PHP online travel website management system to obtain

(PHP graduation project) based on PHP user online submission management system

Trouble encountered in cable testing -- a case study of a manufacturer?

A NOVEL DEEP PARALLEL TIME-SERIES RELATION NETWORK FOR FAULT DIAGNOSIS
随机推荐
An example of bill printing
4、 Model optimizer and inference engine
Create a basic report using MS chart controls
Word邮件合并功能详解:合并后生成多个word文档,删除空白页
福禄克DSX2-5000 网络线缆测试仪为什么每年都要校准一次?
VAN(DWConv+DWDilationConv+PWConv)
线缆测试中遇到苦恼---某厂商案例分析?
Design and analysis of contactor coil control circuit
福禄克DTX-1800其配件DTX-CHA002通道适配器CHANNEL更换RJ45插座小记
Fluke dtx-sfm2 single mode module of a company in Hangzhou - repair case
How can fluke dsx2-5000 and dsx2-8000 modules find the calibration expiration date?
Example of frameset usage
Convert data in grilview into datatable
Led selection - hardware learning notes 3
ICC2(一)Preparing the Design
如何测试工业以太网线缆(利用FLUKE DSX-8000)?
Bert bidirectional encoder based on transformer
保研面试中常见的英语问题有哪些?
PyTorch 学习笔记
Beta distribution (probability of probability)
