这是对自己学习燕十八老师mysql教程的总结,非常感谢燕十八老师。

依赖软件:mysql5.6

系统环境:win

连接查询

在谈连接查询之前我们需要对数学上的笛卡尔积有一定的了解

现在有两个集合m和n

m = (m1,m2,.....mx)

n =(n1,n2,.....ny)

m*n得到的笛卡尔积有多少个元素?

答:m*n有x*y个元素

连接查询有以下类型

1、左连接

2、右连接

3、内连接

连接查询的作用

从2张或多张表中取出有关联的数据

3种连接查询的详细说明

1、左连接

A left join B on 条件;
这样形成了一个结果集,可以看成一张表 设为C
C表有A,B中的所有列;可以做所有表的操作

考虑到兼容问题和理解上的容易程度都推荐用左连接

# 语法
Select 查询项
from
表名 left join 表名 on 表名.列名 = 表名.列名 # 我是这样理解左连接的:左表不动,右表来匹配 # 示例
# 用左连接取出两表cat_id 对应的cat_name
select goods_id,goods.cat_id,category.cat_id,cat_name,goods_name
from
goods left join category on goods.cat_id=category.cat_id;

2、右连接

左右连接可以互换

A left join B <==> B right join A

A right join B on 条件;
这样形成了一个结果集,可以看成一张表 设为C
C表有A,B中的所有列;可以做所有表的操作

# 语法
Select 查询项
from
表名 right join 表名 on 表名.列名 = 表名.列名 # 我是这样理解右连接的:右表不动,左表来匹配 # 示例
# 用右连接取出两表cat_id 对应的cat_name
select goods_id,goods.cat_id,category.cat_id,cat_name,goods_name
from
category right join goods on category.cat_id=goods.cat_id;

3、内连接

B inner join A on 条件;
这样形成了一个结果集,可以看成一张表 设为C
C表有A,B中的所有列;可以做所有表的操作

# 语法
Select 查询项
from
表名 inner join 表名 on 表名.列名 = 表名.列名 # 我是这样理解内连接的:右左连接的交集 # 示例
# 用内连接取出两表cat_id 对应的cat_name
select goods_id,goods.cat_id,category.cat_id,cat_name,goods_name
from
goods inner join category on category.cat_id=goods.cat_id;

小练习

要求:

Match的hostTeamID与guestTeamID都与Team中的teamID关联
查出 2006-6-1 到2006-7-1之间举行的所有比赛,并且用以下形式列出:
拜仁 2:0 不来梅 2006-6-21

建表时特别主要match是mysql的关键字

select t1.teamName,match_Result,t2.teamName,match_Time
from
match1 left join Team as t1
on match1.hostTeamID=t1.teamID
left join Team as t2
on match1.guestTeamID =t2.teamID
where match_Time between '2006-06-01 and '2006-07-01';

联合查询

union查询

使用条件:只要列数一样即可合并(唯一要求)

语法:

sql1 union sql2 表操作

union对重复行的处理:union会去重,union all 不去重复

# 示例1
# 用union取出第4个栏目的商品,第5个栏目的商品,并按价格升序排列 select cat_id,shop_price,goods_name from goods where cat_id=4
union
select cat_id,shop_price,goods_name from goods where cat_id=5
order by shop_price asc;

内层的order by 如果没有影响结果集的结果则将被优化过滤掉

# 示例2
# 用union查出第三个栏目下价格前三高的商品,和第四个栏目下价格前2高的商品
(select cat_id,shop_price,goods_name from goods
where cat_id=3 order by shop_price desc limit 3)
union
(select cat_id,shop_price,goods_name from goods
where cat_id=4 order by shop_price desc limit 2);

小练习

要求:

将两张结构一样的表相同id的值相加,返回所有id和值

# 第一步 将两表合并成一张表,即表c
select id,num from a
union all
select id,num from b # 第二步对表c from型子查询操作,
select id,sum(num) as num
from (select id,num from a
union all
select id,num from b) as c
group by id;

mysql--浅谈多表查询1的更多相关文章

  1. Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理

    基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...

  2. mysql 数据操作 单表查询 目录

    mysql 数据操作 单表查询 mysql 数据操作 单表查询 简单查询 避免重复DISTINCT mysql 数据操作 单表查询 通过四则运算查询 mysql 数据操作 单表查询 concat()函 ...

  3. mysql 数据操作 多表查询 目录

    mysql 数据操作 多表查询 准备 多表连接查询介绍 mysql 数据操作 多表查询 多表连接查询 笛卡尔积 mysql 数据操作 多表查询 多表连接查询 内连接 mysql 数据操作 多表查询 多 ...

  4. MySQL数据库语法-多表查询练习一

    MySQL数据库语法-多表查询练习一 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要介绍的多表查询的外键约束,以及如何使用外链接和内连接查询数据信息. 一.数据表和测试 ...

  5. mysql 数据操作 单表查询 where 约束 目录

    mysql 数据操作 单表查询 where约束 between and or mysql 数据操作 单表查询 where约束 is null in mysql 数据操作 单表查询 where约束 li ...

  6. mysql 数据操作 单表查询 group by 分组 目录

    mysql 数据操作 单表查询 group by 介绍 mysql 数据操作 单表查询 group by 聚合函数 mysql 数据操作 单表查询 group by 聚合函数 没有group by情况 ...

  7. MySQL数据库之单表查询中关键字的执行顺序

    目录 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 2 执行顺序 3 关键字使用语法 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 select distinct from ...

  8. mysql中的回表查询与索引覆盖

    了解一下MySQL中的回表查询与索引覆盖. 回表查询 要说回表查询,先要从InnoDB的索引实现说起.InnoDB有两大类索引,一类是聚集索引(Clustered Index),一类是普通索引(Sec ...

  9. MySQL数据库语法-单表查询练习

    MySQL数据库语法-单表查询练习 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要是对聚合函数和分组的练习. 一.数据表和测试数据准备 /* @author :yinz ...

  10. mysql 基础入门 单表查询

    单表查询 select 表头,表头 as 别名 ,表头(+-*/的运算) from table_a 1.条件查询 where + 条件 <> , != 不等于 = 等于,也可以表示字符串值 ...

随机推荐

  1. 学习使用ExpressJS 4.0中的新Router

    概述 ExpressJS 4.0中提出了新的路由Router.Router好比是一个"迷你版"的express应用,它没有引入views或者settings,但是提供了路由应有的A ...

  2. Laravel的初始化安装

    Laravel的初始化安装 composer 安装 composer中国镜像laravel文档 curl -sS https://getcomposer.org/installer | php # 修 ...

  3. struts + hibernate笔记

    1.hibernate: 1) Restrictions.eq  判断是否相等== (场景:一个类A中的属性t,这个属性t是另一个类B中的ID,找出输入为这个属性t的所有类A) tasks = ses ...

  4. URAL - 1297 Palindrome —— 后缀数组 最长回文子串

    题目链接:https://vjudge.net/problem/URAL-1297 1297. Palindrome Time limit: 1.0 secondMemory limit: 64 MB ...

  5. SpringMVC的API和Spring的官方说明文档的地址。

    SpringMVC的API和Spring的官方说明文档的地址. 1.SpringMVC的API的URL: http://docs.spring.io/spring/docs/current/javad ...

  6. BZOJ 1232 [Usaco2008Nov]安慰奶牛cheer:最小生成树【树上dfs性质】

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1232 题意: 给你一个无向图,n个点,m条边. 每条边有边权len[i][j],每个点有点 ...

  7. 实现远程连接MySQL

    首先登录远程服务器,然后登录mysql:mysql -u用户 -p密码; 创建允许远程登录的用户并赋权:grant all privileges on 数据库.表名 to 用户名@'IP地址' ide ...

  8. IntelliJ IDEA 同时启动多个Tomcat实例端口是会冲突

  9. Log4j 与 logback对比、及使用配置

    二.参考文档 1.Log4j 与 logback对比.及使用配置

  10. storm源码剖析(1):storm脚本

    今天看了一下storm的命令行脚本${STORM_HOME}/bin/storm,现在将剖析过程整理一下,作为记录.注:使用的storm版本为0.8.0. ${STORM_HOME}/bin/stor ...