mysqlsql连接查询语句_Mysql——sql数据库中的连接查询1.1.1  交叉连接(CROSS JOIN)
交叉连接(CROSS JOIN):有两种,显式的和隐式的,不带ON⼦句,返回的是两表的乘积,也叫笛卡尔积。
例如:下⾯的语句1和语句2的结果是相同的。
为什么存在很多种编程语言
语句1:隐式的交叉连接,没有CROSS JOIN。
SELECT O.ID, O.ORDER_NUMBER, C.ID, C.NAME
FROM ORDERS O , CUSTOMERS C
mysql面试题sql语句多表联查
WHERE O.ID=1;
语句2:显式的交叉连接,使⽤CROSS JOIN。
SELECT
O.ID,O.ORDER_NUMBER,C.ID,
C.NAME
FROM ORDERS O CROSS JOIN
CUSTOMERS C
update会锁表吗
WHERE O.ID=1;
语句1和语句2的结果是相同的,查询结果如下:
1.1.2  内连接(INNER JOIN)
内连接(INNER
JOIN):有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据⾏。(所谓的链接表就是数据库在做查询形成的中间表)。
例如:下⾯的语句3和语句4的结果是相同的。
语句3:隐式的内连接,没有INNER JOIN,形成的中间表为两个表的笛卡尔积。
SELECT
O.ID,O.ORDER_NUMBER,C.ID,C.NAME
FROM CUSTOMERS C,ORDERS
O
WHERE
C.ID=O.CUSTOMER_ID;
语句4:显⽰的内连接,⼀般称为内连接,有INNER JOIN,形成的中间表为两个表经过ON条件过滤后的笛卡尔积。
SELECT
O.ID,O.ORDER_NUMBER,C.ID,C.NAME
FROM CUSTOMERS C INNER
JOIN ORDERS O ON C.ID=O.CUSTOMER_ID;
语句3和语句4的查询结果:
1.1.3  外连接(OUTER JOIN):
外连不但返回符合连接和查询条件的数据⾏,还返回不符合条件的⼀些⾏。
selenium提高爬虫速度1.1.3.1
外连接分三类:左外连接(LEFT
OUTER JOIN)、右外连接(RIGHT OUTER JOIN)和全外连接(FULL OUTER JOIN)。
1.1.3.2
三者的共同点
是都返回符合连接条件和查询条件(即:内连接)的数据⾏。
1.1.3.3
不同点如下:
左外连接还返回左表中不符合连接条件单符合查询条件的数据⾏。
右外连接还返回右表中不符合连接条件单符合查询条件的数据⾏。
全外连接还返回左表中不符合连接条件单符合查询条件的数据⾏,并且还返回右表中不符合连接条件单符合查询条件的数据⾏。全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 UNION 右外”。
说明:左表就是在“(LEFT OUTER JOIN)”关键字左边的表。右表当然就是右边的了。在三种类型的外连接中,OUTER 关键字是可省略的。
下⾯举例说明:
语句5:左外连接(LEFT OUTER JOIN)
SELECT
O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER
JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
语句6:右外连接(RIGHT OUTER JOIN)
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O RIGHT
c语言题库app哪个好OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
注意:WHERE条件放在ON后⾯查询的结果是不⼀样的。例如:
语句7:WHERE条件独⽴。
SELECT
O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER
JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID
WHERE
O.ORDER_NUMBER<>'MIKE_ORDER001';
语句8:将语句7中的WHERE条件放到ON后⾯。
SELECT
O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER
JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID AND
O.ORDER_NUMBER<>'MIKE_ORDER001';
从语句7和语句8查询的结果来看,显然是不相同的,语句8显⽰的结果是难以理解的。因此,推荐在写连接查询的时候,ON后⾯只跟连接条件,⽽对中间表限制的条件都写到WHERE⼦句中。
语句9:全外连接(FULL OUTER JOIN)。
SELECT
O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O FULL OUTER
JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
注意:MySQL是不⽀持全外的连接的,这⾥给出的写法适合Oracle和DB2。但是可以通过左外和右外求合集来获取全外连接的查询结果。下图是上⾯SQL在Oracle下执⾏的结果:
语句10:左外和右外的合集,实际上查询结果和语句9是相同的。
SELECT
O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER
JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID
eclipse配置jdk环境变量配置UNION
SELECT
O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O RIGHT
OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
语句9和语句10的查询结果是相同的,如下:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。