SQL2-子查询、join查询

SQL常用高级查询包括:Join查询、子查询。

子查询:

USE flowershopdb

--子查询:在一个select语句使用另一个select 语句作为条件或数据来源.
--查询块:一个select子句.
--嵌套查询:在一个查询块中嵌套另一个查询块.内层查询叫子查询,外层查询叫主查询.


--1 不相关子查询:子查询不依赖于主查询,子查询可以独立执行.

--作为条件
SELECT * FROM tb_detailed 
WHERE c_id = (SELECT c_id FROM tb_category WHERE c_name='生日花')
--作为列
SELECT (SELECT c_name FROM tb_category WHERE c_id=1000),(SElECT d_remark FROM tb_detailed WHERE d_id=2000)

--2 相关子查询:子查询依赖于主查询,子查询不可以独立执行.
SELECT de.* FROM tb_detailed de
WHERE de.c_id = (SElECT ca.c_id FROM tb_category ca WHERE ca.c_id=1001 AND ca.c_id=de.d_id )


--关键字:IN ALL ANY
--注:子查询必需有括起来().
--IN    表示查询结果是否在子查询结果集中
--All    表示查询结果要满足子查询的所有条件
--Any    表示查询结果要满足子查询的的任一个条件

-- IN 用于多个结果集
SELECT * FROM tb_detailed 
WHERE d_id IN (SElECT d_id FROM tb_detailed WHERE d_remark='生日用花')

-- ALL
-- >all、<all、>=all、<all
SELECT de.* FROM tb_detailed de
WHERE de.d_id > ALL(SElECT pr.d_id FROM tb_product pr WHERE pr.p_price>3)
--相当于
SELECT de.* FROM tb_detailed de
WHERE de.d_id > (SElECT MAX(pr.d_id) FROM tb_product pr WHERE pr.p_price>3)

-- ANY
-- >any、<any、<=any、>=any
SELECT de.* FROM tb_detailed de
WHERE de.d_id > ANY(SElECT pr.d_id FROM tb_product pr WHERE pr.p_price>3)
--相当于
SELECT de.* FROM tb_detailed de
WHERE de.d_id > ANY(SElECT MIN(pr.d_id) FROM tb_product pr WHERE pr.p_price>3)

--关键字:
--EXISTS 用于检查子查询是否至少会返回一行数据,该子查询实际上不返回任何数据,而是返回true或false【指定子查询,检测行的存在】

SELECT * FROM tb_user  WHERE EXISTS (SELECT NULL)
--等同于
SELECT * FROM tb_user

SELECT de.* FROM tb_detailed de
WHERE EXISTS(SElECT ca.c_id FROM tb_category ca WHERE ca.c_id=1001 AND ca.c_id=de.d_id )
--等同于
SELECT de.* FROM tb_detailed de
WHERE de.c_id IN(SElECT ca.c_id FROM tb_category ca WHERE ca.c_id=1001 AND ca.c_id=de.d_id )


--NOT EXISTS 如果子查询没有返回行,则满足Not Exists中的Where子句
SELECT de.* FROM tb_detailed de
WHERE NOT EXISTS(SElECT ca.c_id FROM tb_category ca WHERE ca.c_id=1001 AND ca.c_id=de.d_id )

Join查询:

CREATE DATABASE selectdb
USE selectdb

SELECT * FROM A
SELECT * FROM B

--多表条件查询
SELECT * FROM A,B WHERE A.A=B.A

--Jion表连接
--[join是和哪个表连接,on后是连接的关系是什么]

--内连接 INNER JOIN
-- 只连接匹配的行
SELECT A.A,A.B,A.C,B.D,B.E FROM A INNER JOIN B 
ON A.A=B.A

--左外连接 LEFT [OUTER] JOIN 
--包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行
SELECT A.A,A.B,A.C,B.D,B.E FROM A LEFT JOIN B 
ON A.A=B.A

--右外连接 RIGHT [OUTER] JOIN
--包含右边表的全部行(不管左边的表中是否存在与它们匹配的行),以及左边表中全部匹配的行 
SELECT A.A,A.B,A.C,B.D,B.E FROM A RIGHT JOIN B 
ON A.A=B.A

--全连接 FULL [OUTER] JOIN 
-- 包含左、右两个表的全部行,不管另外一边的表中是否存在与它们匹配的行。
SELECT A.A,A.B,A.C,B.D,B.E FROM A FULL JOIN B 
ON A.A=B.A

--交叉连接 CROSS JOIN 
-- 生成笛卡尔积-它不使用任何匹配或者选取条件,而是直接将一个数据源中的每个行与另一个数据源的每个行都一一匹配
--A中的每一条数据与B中的每一条数据交叉 3*3
SELECT * FROM A CROSS JOIN B 

--自连接
--自身连接是指同一个表自己与自己进行连接。这种一元连接通常用于从自反关系(也称作递归关系)中抽取数据。
SELECT *
FROM B b1
JOIN B b2
ON b1.A=b2.D

SELECT * FROM B

更多查询链接:http://www.cnblogs.com/hoojo/archive/2011/07/16/2108129.html

原文地址:https://www.cnblogs.com/wykLog/p/4280163.html