MySQL多表联合查询是MySQL数据库的一种查询方式,下面就为您介绍MySQL多表联合查询的语法,供您参考学习之用。

MySQL多表联合查询语法:   

SELECT   *    FROM   插入表   LEFT JOIN   主表   ON   t1.lvid=t2.lv_id     select * from mytable,title where 表名1.name=表名2.writer ;

 mysql版本大于4.0,使用UNION进行查询,示例如下:   

SELECT `id`, `name`, `date`, ‘’ AS `type` FROM table_A WHERE 条件语句……
   UNION
SELECT `id`, `name`, `date`, ‘未完成’ AS `type` FROM table_B WHERE 条件语句……
  ORDER BY `id` LIMIT num;

mysql版本小于4.0,需要建立临时表,分为三步,示例如下:

   第一步:建立临时表tmp_table_name并插入table_A中的相关记录      

$sql = “CREATE TEMPORARY TABLE tmp_table_name SELECT `id`, `name`, `date`, ‘完成’ AS `type` FROM table_A WHERE 条件语句……”;                            

   第二步:从table_B中取得相关记录插入临时表tmp_table_name中

INSERT INTO tmp_table_name SELECT `id`, `name`, `date2` AS `date`, ‘未完成’ AS `type` FROM table_B WHERE 条件语句……

   第三步:从临时表tmp_table_name中取出记录

SELECT * FROM tmp_table_name ORDER BY id DESC

union和order by、limit区别分析   

代码示例:
CREATE TABLE `test1` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
`desc` varchar(100) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

1,以下查询会报错误:[Err] 1221 - Incorrect usage of UNION and ORDER BY

代码示例:
select * from test1 where name like 'A%' order by name
union
select * from test1 where name like 'B%' order by name

修改为:

代码示例:
select * from test1 where name like 'A%'
union
select * from test1 where name like 'B%' order by name

说明,在union中,不用括号的情况下,只能用一个order by(思考:union两边的order by的列名不一样时,会出现什么样的结果?),这会对union后的结果集进行排序。
修改为:

代码示例:
(select * from test1 where name like 'A%' order by name)
union
(select * from test1 where name like 'B%' order by name)
也是可以的,这两个order by在union前进行。

2,同样

代码示例:
select * from test1 where name like 'A%' limit 10
union
select * from test1 where name like 'B%' limit 20

相当于:

代码示例:
(select * from test1 where name like 'A%' limit 10)
union
(select * from test1 where name like 'B%') limit 20

即后一个limit作用于的是union后的结果集,而不是union后的select。
也可以用括号括起来,以得到预期的结果:

3,UNION和UNION ALL区别
union会过滤掉union两边的select结果集中的重复的行,而union all不会过滤掉重复的行。

代码示例:
(select * from test1 where name like 'A%' limit 10)
union
(select * from test1 where name like 'B%' limit 20)

  下面试一个年龄段分析的复杂sql语句

(
SELECT
'5~19' AS `age`,
SUM(`impression`) AS impression,
SUM(`click`) AS click,
sum(`cost`) AS cost
FROM
`adgroup_age_report`
WHERE
(
(
(`age` <= 19)
AND (`adgroup_id` = '61')
)
AND (`date` >= '2015-11-22')
)
AND (`date` <= '2017-02-20')
)
UNION
(
SELECT
'20~29' AS `age`,
SUM(`impression`) AS impression,
SUM(`click`) AS click,
sum(`cost`) AS cost
FROM
`adgroup_age_report`
WHERE
(
(
((`age` <= 29) AND(`age` >= 20))
AND (`adgroup_id` = '61')
)
AND (`date` >= '2015-11-22')
)
AND (`date` <= '2017-02-20')
)
UNION
(
SELECT
'30~39' AS `age`,
SUM(`impression`) AS impression,
SUM(`click`) AS click,
sum(`cost`) AS cost
FROM
`adgroup_age_report`
WHERE
(
(
((`age` <= 39) AND(`age` >= 30))
AND (`adgroup_id` = '61')
)
AND (`date` >= '2015-11-22')
)
AND (`date` <= '2017-02-20')
)
UNION
(
SELECT
'40~49' AS `age`,
SUM(`impression`) AS impression,
SUM(`click`) AS click,
sum(`cost`) AS cost
FROM
`adgroup_age_report`
WHERE
(
(
((`age` <= 49) AND(`age` >= 40))
AND (`adgroup_id` = '61')
)
AND (`date` >= '2015-11-22')
)
AND (`date` <= '2017-02-20')
)
UNION
(
SELECT
'50~59' AS `age`,
SUM(`impression`) AS impression,
SUM(`click`) AS click,
sum(`cost`) AS cost
FROM
`adgroup_age_report`
WHERE
(
(
((`age` <= 59) AND(`age` >= 50))
AND (`adgroup_id` = '61')
)
AND (`date` >= '2015-11-22')
)
AND (`date` <= '2017-02-20')
)

假设表

需要得到以下结果

SELECT name,
MAX(
CASE
WHEN subject='语文'
THEN score
ELSE 0
END) AS "语文",
MAX(
CASE
WHEN subject='数学'
THEN score
ELSE 0
END) AS "数学",
MAX(
CASE
WHEN subject='英语'
THEN score
ELSE 0
END) AS "英语"
FROM student
GROUP BY name

  假设表

需要得到以下结果

SELECT
NAME,
'语文' AS subject ,
MAX("语文") AS score
FROM student1 GROUP BY NAME
UNION
SELECT
NAME,
'数学' AS subject ,
MAX("数学") AS score
FROM student1 GROUP BY NAME
UNION
SELECT
NAME,
'英语' AS subject ,
MAX("英语") AS score
FROM student1 GROUP BY NAME

  

统计表中出现次数大于1的数据

 select ewm_id,count(invoice_id) from y_ewm_invoice_relation GROUP BY ewm_id HAVING count(invoice_id) > 1

  

根据不同条件汇总

SELECT SUM(IF(state = 2,1,0)) AS `state`,
SUM(IF(state = 1,1,0)) AS `state`,
COUNT(`state`) AS `all` FROM individual_certify

  

mysql 经典案例的更多相关文章

  1. Mysql 经典案例总结(学习之前需要有Mysql基础)01

    Sql 经典案例 gb 4.2 ** 1 检索记录 (1) 主要介绍 Sql的基本SELECT查询语句 使用 SELECT * from 表 查询数据 查询该表的每一列数据 * 代表所有的意思 也可以 ...

  2. 【MySQL经典案例分析】关于数据行溢出由浅至深的探讨

    本文由云+社区发表 一.从常见的报错说起 ​ 故事的开头我们先来看一个常见的sql报错信息: ​ 相信对于这类报错大家一定遇到过很多次了,特别对于OMG这种已内容生产为主要工作核心的BG,在内容线的存 ...

  3. MySQL的InnoDB表如何设计主键索引-转自淘宝MySQL经典案例

    创建a表 id主键 CREATE TABLE `a` (`id` bigint(20) NOT NULL AUTO_INCREMENT ,`message_id` int(11) NOT NULL,` ...

  4. 【MySQL经典案例分析】 Waiting for table metadata lock

    本文由云+社区发表 一. 问题是这样来的 ​ 2018年某个周末,接到连续数据库的告警,告警信息如下: 二. 苦逼的探索过程 1.总体的思路 看到too many connection的报错信息,基本 ...

  5. mysql经典案例分析

    问题: create table A ( id varchar(64) primary key, ver int, ...)在id,ver上有联合索引,10000条数据为什么select id fro ...

  6. MySQL进阶8 分页查询(limit) - 【SQL查询语法执行顺序及大致结构】- 子查询的3个经典案例

    #进阶8 分页查询 /* 应用场景: 当要显示的数据,一页显示不全,需要分页提交sql请求 语法: select 查询列表 #7 from 表1 #执行顺序:#1 [join type join 表2 ...

  7. Linux运维之道(大量经典案例、问题分析,运维案头书,红帽推荐)

    Linux运维之道(大量经典案例.问题分析,运维案头书,红帽推荐) 丁明一 编   ISBN 978-7-121-21877-4 2014年1月出版 定价:69.00元 448页 16开 编辑推荐 1 ...

  8. 阿里云资深DBA专家罗龙九:云数据库十大经典案例分析【转载】

    阿里云资深DBA专家罗龙九:云数据库十大经典案例分析 2016-07-21 06:33 本文已获阿里云授权发布,转载具体要求见文末 摘要:本文根据阿里云资深DBA专家罗龙九在首届阿里巴巴在线峰会的&l ...

  9. 汇总java生态圈常用技术框架、开源中间件,系统架构及经典案例等

    转自:http://www.51testing.com/html/83/n-3718883.html 有人认为编程是一门技术活,要有一定的天赋,非天资聪慧者不能及也.非也,这是近几年,对于技术这碗饭有 ...

随机推荐

  1. arts-week14

    Algorithm 923. 3Sum With Multiplicity - LeetCode Review Building a network attached storage device w ...

  2. 274. H-Index - LeetCode

    Question 274. H-Index Solution 题目大意: 论文里的 h 因子判定,题目的意思可能有点晦涩.h 因子是评判学术成就的一种重要方法,h 因子越高越好,h 因子兼顾研究学术人 ...

  3. [C++STL] vector 容器的入门

    vector容器的入门 #include<vector> 创建vector容器的几种方式 数据类型可以是结构体,也能是另外一个容器 vector 的初始化: (1) 创建并声明大小 vec ...

  4. e2fsck-磁盘分区修复

    检查 ext2/ext3/ext4 类型文件系统. 语法 e2fsck [-panyrcdfvtDFV] [-b superblock] [-B blocksize] [-I inode_buffer ...

  5. 做一个能对标阿里云的前端APM工具(下)

    上篇请访问这里做一个能对标阿里云的前端APM工具(上) 样本多样性问题 上一小节中的实施方案是微观的,即单次性的.具体的.但是从宏观上看,我需要保证性能测试是公允的,符合大众预期的.为了达到这种效果, ...

  6. 【Azure 存储服务】Java Azure Storage SDK V12使用Endpoint连接Blob Service遇见 The Azure Storage endpoint url is malformed

    问题描述 使用Azure Storage Account的共享访问签名(Share Access Signature) 生成的终结点,连接时遇见  The Azure Storage endpoint ...

  7. 给小白的 PG 容器化部署教程(下)

    作者:王志斌 编辑:钟华龙 本文来自社区小伙伴 王志斌 的投稿.从小白的角度,带你一步步实现将 RadonDB PostgreSQL 集群部署到 Kubernetes 上.文章分为上下两部分,< ...

  8. docker的数据存储

    概述 Docker 为容器提供了两种存放数据的资源:由 storage driver 管理的镜像层和容器层:以及Data Volume. store driver Docker镜像的分层结构如下图所示 ...

  9. 4. Docker自定义镜像

    下面制作镜像: 此时,验证一下: 以上验证都是成功的,到此就可以把刚才建立并经过刚才运行并验证的镜像包通过各种方式传递给其他人来部署使用了,并且环境肯定是可你统一的.

  10. 整数分解、for循环阶乘

    整数分解 整数分解是什么呢??我们可以这样理解 我们写一个 3位数求出它的个位十位和百位 . 那么我们来写一个小的测试来看一下! public static void main(String[] ar ...