##多表查询

##使用数据库 mytest
USE mytest; ##删除,并重新创建表 t_dept
DROP TABLE t_dept;
CREATE TABLE t_dept (
deptno INT(11) NOT NULL,
dname VARCHAR(20) NOT NULL,
loc VARCHAR(40),
UNIQUE INDEX uk_deptno(deptno)
)
##创建测试表 t_a
CREATE TABLE t_A (
aId INT (11) AUTO_INCREMENT, ##主键,自增
aName VARCHAR (20) NOT NULL,
loc VARCHAR (40),
cId INT(11),
PRIMARY KEY pk_aId (aId)
) ;
##创建测试表 t_b
CREATE TABLE t_B (
bId INT (11) AUTO_INCREMENT, ##主键,自增
bStand VARCHAR (40) NOT NULL,
aId INT (11) NOT NULL,
PRIMARY KEY pk_bId (bId),
UNIQUE INDEX uk_aId (aId) ##唯一索引
) ;
##创建测试表 t_c
CREATE TABLE t_c (
cId INT (11) AUTO_INCREMENT, ##主键,自增
cvalue VARCHAR (20) NOT NULL,
PRIMARY KEY pk_cId (cId)
);
##创建测试表 t_d
CREATE TABLE t_d(
xname VARCHAR(11),
xsex VARCHAR(11)
);
##创建测试表 t_e
CREATE TABLE t_e(
xname VARCHAR(11),
xsex VARCHAR(11)
); ##删除唯一索引
ALTER TABLE t_b
DROP KEY uk_aId; ##插入测试数据
INSERT INTO t_dept(deptno,dname,loc)
VALUES
(10,'生产','生产部'),
(20,'业务','业务部'),
(30,'品质','品质部'),
(40,'人事','人事部'),
(50,'工程','工程部'); INSERT INTO t_a (aName, loc,cId)
VALUES
('Jay', 'Jay Chou',1),
('Join', 'Join Chang',3),
('Hebe', 'Hebe Young',2),
('Jack', 'Jack Son',2),
('Smile', 'Smile Kiss',1) ; INSERT INTO t_b (bStand, aId)
VALUES
('Jay-Jay Chou', 1),
('Hebe-Hebe Young', 3),
('Jack-Jack Son', 4),
('Smile-Smile Kiss', 5) ; INSERT INTO t_c (cvalue)
VALUES ('鸡'),('牛'),('马'); INSERT INTO t_d (xname,xsex)
VALUES ('章子怡','女'),('张筱雨','女'),('张雨涵','男'),('张予曦','女'),('张曦予','女'); INSERT INTO t_e (xname,xsex)
VALUES ('张曦予','女'),('汪峰','男'),('张馨予','女'); -- ----------- 内联、外联不推荐使用,根据笛卡尔积,执行效率低于子查询 ----------- --
##内联 □■□
##INNER JOIN …… ON。显示主副表数据交集
SELECT a.aid,a.aName,a.loc,b.bStand,c.cvalue
FROM t_a AS a
INNER JOIN t_b AS b
ON a.aId = b.aId
INNER JOIN t_c AS c
ON a.cId=c.cId; ##外联 ■■□ OR □■■
##外联显示的数据以主表为准,不管副表是否有对应数据都会显示,副表无数据的,显示null。■■□
##内联,副表无对应数据,则不会显示出。简而言之,显示数据为主副表的 交集。□■□ ##左联:以本表为主表,左联表为副表。■■□
SELECT a.aid,a.aName,a.loc,b.bStand
FROM t_a AS a
LEFT JOIN t_b AS b
ON a.aid=b.aid; ##右联:以本表为副表,右联表为主表。□■■
SELECT a.aid,a.aName,a.loc,b.bStand
FROM t_a AS a
RIGHT JOIN t_b AS b
ON a.aid=b.aid; ##合并查询:
SELECT * FROM t_d UNION SELECT * FROM t_e; ## UNION,去掉两表的重复数据。 ■■■
SELECT * FROM t_d UNION ALL SELECT * FROM t_e; ## UNION ALL, 未去掉两表的重复数据。 ■■■■ -- ----------- 子查询 推荐使用,根据笛卡尔积,执行效率高 ----------- -- SELECT COUNT(*) FROM t_a AS a,t_b AS b; ##笛卡尔积 SELECT * FROM t_a
WHERE cId=(SELECT cId FROM t_a WHERE aName = 'Jay'); ##结果集可以是多行 SELECT * FROM t_a
WHERE (aId,loc) = ( SELECT aId,loc FROM t_a WHERE cId=3); ##结果集只能是单行 SELECT * FROM t_employee
WHERE deptno IN ( SELECT deptno FROM t_dept); SELECT * FROM t_employee
WHERE deptno NOT IN ( SELECT deptno FROM t_dept); ##使用ANY。在使用上,用 <= 和 >= 更有意义 ■■□
## <ANY (<=ANY) ,结果集是比最小值(包含)大的结果。
## >ANY (>=ANY) ,结果集是比最大值(包含)小的结果。
## =ANY,与使用 IN 一样。
SELECT sal FROM t_employee
WHERE job='SALESMAN'; SELECT * FROM t_employee
WHERE sal>=ANY(SELECT sal FROM t_employee WHERE job='SALESMAN'); ##使用ALL。在使用上,用 < 和 > 更有意义 ■□□
## <ALL (<=ALL) ,结果集是比最大值(包含)更大的结果。
## >ALL (>=ALL) ,结果集是比最小值(包含)更小的结果。
## =ANY,与使用 IN 一样。
SELECT sal FROM t_employee
WHERE job='SALESMAN'; SELECT * FROM t_employee
WHERE sal>ALL(SELECT sal FROM t_employee WHERE job='SALESMAN'); ##使用 EXISTS 与IN 的使用效果类似,以下两条SQL语句执行结果一致。
SELECT *
FROM t_dept AS d
WHERE EXISTS( SELECT * FROM t_employee WHERE deptno=d.deptno); SELECT * FROM t_dept AS d
WHERE deptno IN( SELECT deptno FROM t_employee); -- 综合测试 --
##计算笛卡尔积
SELECT COUNT(empno) FROM t_employee;
SELECT COUNT(deptno) FROM t_dept;
SELECT COUNT(*) FROM t_employee,t_dept; ##使用内联,无字段为NULL,但效率低(笛卡尔积为 9X5=45)
SELECT d.deptno,d.dname,d.loc,COUNT(e.empno) AS number, AVG(e.sal) AS average
FROM t_dept AS d INNER JOIN t_employee AS e
ON d.deptno = e.deptno
GROUP BY d.deptno; ##使用左联,有字段为NULL,且效率低(笛卡尔积为 9X5=45)
SELECT d.deptno,d.dname,d.loc,COUNT(e.empno) AS number,AVG(e.sal) AS average
FROM t_dept AS d LEFT JOIN t_employee AS e
ON d.deptno=e.deptno
GROUP BY d.deptno; ##使用右联,虽无字段为NULL,但无法保证其他情况没NULL,且效率低(笛卡尔积为 9X5=45)
SELECT d.deptno,d.dname,d.loc,COUNT(e.empno) AS number,AVG(e.sal) AS average
FROM t_employee AS e LEFT JOIN t_dept AS d
ON d.deptno=e.deptno
GROUP BY d.deptno; ##使用子查询。最好为每个表派生别名,并指出每个字段是哪张表的。(防止字段之间重名)
##效率高,笛卡尔积为(4+9=13)
SELECT d.deptno,d.dname,d.loc,e.number,e.average
FROM t_dept AS d,
(SELECT deptno, COUNT(empno) AS number,AVG(sal) AS average
FROM t_employee GROUP BY deptno) AS e
WHERE d.deptno=e.deptno;

所有代码,均为自学时用到的测试与注释,知识细节或知识点不会面面俱到,亦不会有任何讲解,只做为自己学习复习用。

学习MySQL之多表操作(三)的更多相关文章

  1. 学习MySQL之单表操作(二)

    ##单表操作 ##创建表 CREATE TABLE t_employee( empno ), ename ), job ), MGR ), Hiredate DATE DEFAULT '0000-00 ...

  2. {MySQL的库、表的详细操作}一 库操作 二 表操作 三 行操作

    MySQL的库.表的详细操作 MySQL数据库 本节目录 一 库操作 二 表操作 三 行操作 一 库操作 1.创建数据库 1.1 语法 CREATE DATABASE 数据库名 charset utf ...

  3. mysql数据库学习(二)--表操作

    一.表操作 以下内容都是自己学习的时候看过的一些知识,作为笔记记录一下吧,大部分都是所看文章的内容. 1.创建表 前面的基础篇笔记是相当于搭建了一个方便管理的文件夹树根,下面要学习的是一些关于表的知识 ...

  4. day 46 Django 学习3 数据库单表操作以及反向解析

    前情提要: Django 已经学了不少了, 今天学习链接数据库的操作.以及相关的反向解析等 一:反向解析 1:反向解析模板层 跳转时设定url会随着前面的路由改变而改变         2:反向解析之 ...

  5. 数据库之 MySQL --- 数据处理 之 表操作、CRUD(六)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一. 表操作 创建数据库CREATE DATABASE demo-- 删除数据库DROP DATABAS ...

  6. MySQL之多表操作

    前言:之前已经针对数据库的单表查询进行了详细的介绍:MySQL之增删改查,然而实际开发中业务逻辑较为复杂,需要对多张表进行操作,现在对多表操作进行介绍. 前提:为方便后面的操作,我们首先创建一个数据库 ...

  7. Database学习 - mysql 数据库 多表/复合/子 查询

    多表查询 多表查询,基本规则,通过两表有关联字段的进行条件匹配查询 内连接查询 方式一: SELECT 查看字段名[,查看字段名] FROM 一表名,二表名 WHERE 一/二表.字段 = 一/二表. ...

  8. mysql 库与表操作

    1. 库操作 1.1. 创建数据库 语法规则:create database 库名; CREATE DATABASE dt55; 在创建库时,希望指定编码语法:create database 库名 c ...

  9. mysql数据库之表操作及字段约束条件

    目录 一.存储引擎 二.表介绍 三.创建表 四.查看表结构 五.数据类型 一.介绍 二.数值类型 整数类型 浮点型 三.字符串类型 四.日期类型 五.枚举类型与集合类型 六.约束条件 七.修改表 al ...

随机推荐

  1. 关于sql中in 和 exists 的效率问题,in真的效率低吗

    原文: http://www.cnblogs.com/AdamLee/p/5054674.html 在网上看到很多关于sql中使用in效率低的问题,于是自己做了测试来验证是否是众人说的那样. 群众: ...

  2. Spring MVC之@RequestParam @RequestBody @RequestHeader 等详解

    (转自:http://blog.csdn.net/walkerjong/article/details/7946109#) 引言: 接上一篇文章,对@RequestMapping进行地址映射讲解之后, ...

  3. [bzoj3932][CQOI2015][任务查询系统] (主席树)

    Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si ...

  4. sql

    http://www.cnblogs.com/ASPNET2008/archive/2012/06/30/2570737.html

  5. JavaScript第一节课

    1.用法:位于<script></script>可以位于body和head中,不限制标签数量,也可以创建外部Js文件,然后引入.(引入方法:<script src=&qu ...

  6. 有理数的稠密性(The rational points are dense on the number axis.)

    每一个实数都能用有理数去逼近到任意精确的程度,这就是有理数的稠密性.The rational points are dense on the number axis.

  7. Weekly Traning Farm 16

    先安利一下这套比赛,大概是doreamon搞的,每周五晚上有一场,虽然没人做题目质量挺高的 http://codeforces.com/group/gRkn7bDfsN/contests(报名前要先报 ...

  8. java.io.IOException: mark/reset not supported

    java.io.IOException: mark/reset not supported at java.io.InputStream.reset(InputStream.java:348) at ...

  9. 常用jdbc的url

    Microsoft SQL Server Microsoft SQL Server JDBC Driver (一般用来连接 SQLServer 2000) 驱动程序包名:msbase.jar mssq ...

  10. DataTable转List

    Invoke : DataTableToList<City>.ConvertToModel(ds.Tables[0]).ToList<City>(); using System ...