学习MySQL之多表操作(三)
##多表查询 ##使用数据库 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之多表操作(三)的更多相关文章
- 学习MySQL之单表操作(二)
##单表操作 ##创建表 CREATE TABLE t_employee( empno ), ename ), job ), MGR ), Hiredate DATE DEFAULT '0000-00 ...
- {MySQL的库、表的详细操作}一 库操作 二 表操作 三 行操作
MySQL的库.表的详细操作 MySQL数据库 本节目录 一 库操作 二 表操作 三 行操作 一 库操作 1.创建数据库 1.1 语法 CREATE DATABASE 数据库名 charset utf ...
- mysql数据库学习(二)--表操作
一.表操作 以下内容都是自己学习的时候看过的一些知识,作为笔记记录一下吧,大部分都是所看文章的内容. 1.创建表 前面的基础篇笔记是相当于搭建了一个方便管理的文件夹树根,下面要学习的是一些关于表的知识 ...
- day 46 Django 学习3 数据库单表操作以及反向解析
前情提要: Django 已经学了不少了, 今天学习链接数据库的操作.以及相关的反向解析等 一:反向解析 1:反向解析模板层 跳转时设定url会随着前面的路由改变而改变 2:反向解析之 ...
- 数据库之 MySQL --- 数据处理 之 表操作、CRUD(六)
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 一. 表操作 创建数据库CREATE DATABASE demo-- 删除数据库DROP DATABAS ...
- MySQL之多表操作
前言:之前已经针对数据库的单表查询进行了详细的介绍:MySQL之增删改查,然而实际开发中业务逻辑较为复杂,需要对多张表进行操作,现在对多表操作进行介绍. 前提:为方便后面的操作,我们首先创建一个数据库 ...
- Database学习 - mysql 数据库 多表/复合/子 查询
多表查询 多表查询,基本规则,通过两表有关联字段的进行条件匹配查询 内连接查询 方式一: SELECT 查看字段名[,查看字段名] FROM 一表名,二表名 WHERE 一/二表.字段 = 一/二表. ...
- mysql 库与表操作
1. 库操作 1.1. 创建数据库 语法规则:create database 库名; CREATE DATABASE dt55; 在创建库时,希望指定编码语法:create database 库名 c ...
- mysql数据库之表操作及字段约束条件
目录 一.存储引擎 二.表介绍 三.创建表 四.查看表结构 五.数据类型 一.介绍 二.数值类型 整数类型 浮点型 三.字符串类型 四.日期类型 五.枚举类型与集合类型 六.约束条件 七.修改表 al ...
随机推荐
- Oracle数据库的 增、删、改、查
有时候数据库的查询语句一时想不起来,或不确定是不是语句写的正确,现在整理了一下标准的基本查询语句,便于以后牢记: .数据操作语言 DML:添加(insert into).修改(update set ...
- linux下解压.tar.gz .tar.bz2
从网络上下载到的源码包, 最常见的是 .tar.gz 包, 还有一部分是 .tar.bz2包要解压很简单 :.tar.gz 格式解压命令为 tar -zxvpf x ...
- Bluemix中国版体验(一)
很高兴终于拿到了中国版Bluemix的账号!中国版的Bluemix是由世纪互联运营的,这也是世纪互联继Microsoft Azure,Office 365之后运营的又一个国际一线大品牌的云服务. 中国 ...
- docker学习(3) 容器的启动过程
这一节我们来稍微了解下docker原理性的东西 docker run -i -t ubuntu /bin/bash 输入上面这行命令,启动一个ubuntu容器时,到底发生了什么? 大致过程可以用下图描 ...
- [LeetCode] Lexicographical Numbers 字典顺序的数字
Given an integer n, return 1 - n in lexicographical order. For example, given 13, return: [1,10,11,1 ...
- 一个简单的ASP.NET MVC异常处理模块
一.前言 异常处理是每个系统必不可少的一个重要部分,它可以让我们的程序在发生错误时友好地提示.记录错误信息,更重要的是不破坏正常的数据和影响系统运行.异常处理应该是一个横切点,所谓横切点就是各个部分都 ...
- ElasticSearch+Kibana 索引操作( 附源码)
一 前言 ElasticiSearch 简介 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elastics ...
- [转]extjs组件添加事件监听的三种方式
原文地址:http://blog.csdn.net/y6300023290/article/details/18989635 1.在定义组件配置的时候设置 xtype : 'textarea', na ...
- MVC项目中,如何访问Views目录下的静态文件!
<!--注意,是system.webServer节点,而非system.web--><system.webServer> <handlers> <add na ...
- SpringMVC的小总结
---恢复内容开始--- 前言: springMVC是我接触的第一个框架,当时在学校学习的时候还是各种懂,最简单的springMVC框架的配置还是比较熟,后来工作之后,虽然主要用的确实是springM ...