select连接查询

简要:

一、union联合查询

二、左右内连接



一、union联合查询

作用: 把2次或多次查询结果合并起来

具体: (表1查询结果) union (表2查询结果)

运行: 先算表1查询结果,再算表2查询结果。再通过union把结果联合起来。

总结:

a、左右查询结果列数一致

b、终于显示结果以第一张表的列名为主

c、左右查询结果的列类型最好也一致。不然就会进行转换。

由低到高。如表1结果A列为整形,表2结果A列为浮点型。则表1在A列的结果转换为浮点型

d、能够是不同表

e、假设不同的语句中取出的行,有全然同样(每一个列的值都同样),那么同样的行将会合并(去重)

案例:

查询 这种结果:

a16,b 21,c 14,d 41

步骤1: union来获取两张表的查询结果

步骤2: 把步骤1的查询结果看成暂时表

 

不足之处: 上述案例中表ta和tb中不存在全然同样的列(即查询结果中全部列的值都一样)

改动下tb表



此时。运行步骤2的sql语句



发现id为a的值总和为5而不是为10.

这是由于假设不同的语句中取出的行,有全然同样(每一个列的值都同样),那么同样的行将会合并(去重)

处理方案: 用union all

 

 

二、连接查询

通常情况下表与表之间是没有什么关系的。可是我们能够通过一个字段,让表与表发生关系。

把表看成集合。

2.1、左连接

语法: select 列1。列2。列N from tableA left join tableB on tableA.列=tableB.列

2.2、右连接

语法: select 列1,列2,列N from tableA right join tableB on tableA.列=tableB.列

2.3、内连接

语法: select 列1,列2,列N from tableA inner join tableB on tableA.列=tableB.列

2.4、左右内连接的差别

create table boy

( name char(3) not null,

flower char(5)

)engine=myisam charset utf8;

create table girl

( name char(3),

flower char(5)

)engine=myisam charset utf8;

insert into boy values('林书豪','玫瑰'),('刘翔','桃花'),('周杰伦','茉莉花'),('犀利哥','荷花'),

('刘德华','狗尾巴花');

insert into girl values('艾薇尔','玫瑰'),('居里夫人','桃花'),('芙蓉姐','茉莉花'),('凤姐','茉莉花'),('林志玲','荷花');

案例一: 依据花,男找女

左连接

以左表为准。去右表找匹配数据,找不到匹配,用NULL补齐。

总结: tableA为N ;tableB为M。则在以tableA为左表的情况下,得到的数据行数至少为N行。

案例二: 依据花,女找男

总结:
左连接和右连接相互转换。

A
在 B的左边  ==》B在A的右边

A left join B  ==》B rightjoin A

怎样记忆:

1、 左右连接能够相互转化

2、 能够把右连接转换为左连接来使用(兼容其他数据版本号)

案例三: 不管男女,查找有伴的人

总结: 内连接inner join 查询左右连接都有的数据。即得到左右连接的交集

思考: 是否能查出左右连接的并集呢?

答: 眼下不能直接获取,眼下的mysql不支持外链接。

但能够用union联合

The quieter you become,the more you are able to hear!

小贝_mysql select连接查询的更多相关文章

  1. 小贝_mysql三种子查询

    mysql三种子查询 简要: 一.三种子查询 二.三种子查询理解模型 一.mysql 三种子查询 where子查询.from子查询.exists子查询 二.理解模型: 2.1.一个好的模型,便于我们去 ...

  2. 小贝_mysql sql语句优化过程

    sql语句优化 一.SQL优化的一般步骤 (1).通过show status命令了解各种SQL的运行频率. (2).定位运行效率较低的SQL语句-(重点select) (3).通过explain分析低 ...

  3. 小贝_mysql建表以及列属性

    mysql建表以及列属性 简要: 一.建表原则 二.具体的列属性说明 一.建表原则 建表: 事实上就是声明列的过程,数据终于是以文件的形式放在硬盘(内存) 列: 不同的列类型占的空间不一样. 选列的原 ...

  4. 小贝_mysql主从复制作用以及案例

    mysql主从复制 简要: 一.mysql用户授权 二.mysql bin-log日志 三.mysql主从复制   一.mysql用户授权 1.命令 2.作用:进行权限控制 3.样例: (备注: 同意 ...

  5. 小贝_mysql优化学习

    mysql优化 简要: 1.数据库设计优化 2.sql语句优化 3.表切割 4.读写分离技术 一.数据库设计优化 1.表设计要符合三范式.当然,有时也须要适当的逆范式 2.什么是三范式 一范式: 具有 ...

  6. 小贝_mysql select5种子句介绍

    mysql select5种子句介绍 简要 一.五种字句 二.具体解释五种字句 一.五种字句 where.group by.having.order by.limit 二.具体解释五种字句 2.1.理 ...

  7. 小贝_mysql 存储过程

    存储过程 简要: 1.什么是存储过程 2.使用存储过程 一.存储过程 概念类似于函数,就是把一段代码封装起来.当要行这段代码的时候,能够通过调用该存储过程来实现.在封装的语句体里面.能够用if/els ...

  8. 小贝_mysql 触发器使用

    触发器 简要 1.触发器基本概念 2.触发器语法及实战样例 3.before和after差别 一.触发器基本概念 1.一触即发 2.作用: 监视某种情况并触发某种操作 3.观察场景 一个电子商城: 商 ...

  9. 小贝_mysql数据库备份与恢复

    mysql数据库备份与恢复 简要:        一.数据库备份        二.数据库恢复 一.数据库备份 1.备份简单说明 : 系统执行中,增量备份与总体备份 例: 每周日总体备份一次,周一到周 ...

随机推荐

  1. [转]zsh快捷键记录

    转自: http://wdxtub.com/2016/02/18/oh-my-zsh/ 使用技巧 连按两次Tab会列出所有的补全列表并直接开始选择,补全项可以使用 ctrl+n/p/f/b上下左右切换 ...

  2. java jstl标签

    转自:http://blog.csdn.net/liushuijinger/article/details/9143793 JSTL(JSP Standard Tag Library ,JSP标准标签 ...

  3. 【bzoj1925】[Sdoi2010]地精部落 组合数学+dp

    题目描述 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为 N 的山脉 H可分 为从左到右的 N 段,每段有一个独一无二的高度 Hi,其中Hi是1到 ...

  4. 【Luogu】P3047附近的牛(树形DP)

    题目链接 树形DP,设f[i][j]是当前在i点,j步之内有多少牛.从相邻点to的f[to][j-1]转移而来,减去重复计算即可. #include<cstdio> #include< ...

  5. 在SpringBoot中对SpringSecurity的基本使用

    参考文献: Spring Security Architecture What is authentication in Spring Security? Spring Security是一个能够为基 ...

  6. es6总结(十一)--class & decorator

  7. windows8.1如何分盘

    磁盘分区首先要弄明白磁盘物理顺序与逻辑顺序的区别,在[磁盘管理]界面,所显示的前后顺序为物理顺序,这是磁盘上实实在在的物理位置,如下图2的电脑磁盘物理顺序为CFDE.在[资源管理器]界面,所显示的顺序 ...

  8. 【Visual Studio】The project appears to be under source control, but the associated source control plug-in is not installed on this computer

    [问题描述]用 Visual Studio 2013打开一个项目时,出现下面错误: [问题原因]参考 http://codeverge.com/asp.net.web-forms/the-projec ...

  9. dpkg --add-architecture i386 && apt-get update && > apt-get install wine32

    dpkg --add-architecture i386 && apt-get update &&> apt-get install wine32

  10. AC日记——联合权值 洛谷 P1351

    题目描述 无向连通图G 有n 个点,n - 1 条边.点从1 到n 依次编号,编号为 i 的点的权值为W i ,每条边的长度均为1 .图上两点( u , v ) 的距离定义为u 点到v 点的最短距离. ...