小贝_mysql select连接查询
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连接查询的更多相关文章
- 小贝_mysql三种子查询
mysql三种子查询 简要: 一.三种子查询 二.三种子查询理解模型 一.mysql 三种子查询 where子查询.from子查询.exists子查询 二.理解模型: 2.1.一个好的模型,便于我们去 ...
- 小贝_mysql sql语句优化过程
sql语句优化 一.SQL优化的一般步骤 (1).通过show status命令了解各种SQL的运行频率. (2).定位运行效率较低的SQL语句-(重点select) (3).通过explain分析低 ...
- 小贝_mysql建表以及列属性
mysql建表以及列属性 简要: 一.建表原则 二.具体的列属性说明 一.建表原则 建表: 事实上就是声明列的过程,数据终于是以文件的形式放在硬盘(内存) 列: 不同的列类型占的空间不一样. 选列的原 ...
- 小贝_mysql主从复制作用以及案例
mysql主从复制 简要: 一.mysql用户授权 二.mysql bin-log日志 三.mysql主从复制 一.mysql用户授权 1.命令 2.作用:进行权限控制 3.样例: (备注: 同意 ...
- 小贝_mysql优化学习
mysql优化 简要: 1.数据库设计优化 2.sql语句优化 3.表切割 4.读写分离技术 一.数据库设计优化 1.表设计要符合三范式.当然,有时也须要适当的逆范式 2.什么是三范式 一范式: 具有 ...
- 小贝_mysql select5种子句介绍
mysql select5种子句介绍 简要 一.五种字句 二.具体解释五种字句 一.五种字句 where.group by.having.order by.limit 二.具体解释五种字句 2.1.理 ...
- 小贝_mysql 存储过程
存储过程 简要: 1.什么是存储过程 2.使用存储过程 一.存储过程 概念类似于函数,就是把一段代码封装起来.当要行这段代码的时候,能够通过调用该存储过程来实现.在封装的语句体里面.能够用if/els ...
- 小贝_mysql 触发器使用
触发器 简要 1.触发器基本概念 2.触发器语法及实战样例 3.before和after差别 一.触发器基本概念 1.一触即发 2.作用: 监视某种情况并触发某种操作 3.观察场景 一个电子商城: 商 ...
- 小贝_mysql数据库备份与恢复
mysql数据库备份与恢复 简要: 一.数据库备份 二.数据库恢复 一.数据库备份 1.备份简单说明 : 系统执行中,增量备份与总体备份 例: 每周日总体备份一次,周一到周 ...
随机推荐
- 2016-2017 ACM Central Region of Russia Quarterfinal Programming Contest BHanoi tower
B Hanoi tower It has become a good tradition to solve the “Hanoi tower” puzzle at programming contes ...
- 【Luogu】P2596书架(Splay)
题目链接 通过这题我加深了对Splay的理解,原来Splay的子树也是可以接来接去接到别的点上的,而不是只能旋转qwq 具体接的办法就是swap大法. 对于Top操作我们把当前节点Splay到根,然后 ...
- NYOJ——301递推求值(矩阵快速幂)
递推求值 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给你一个递推公式: f(x)=a*f(x-2)+b*f(x-1)+c 并给你f(1),f(2)的值,请求出f(n)的 ...
- BZOJ 4868 [Shoi2017]期末考试 ——三分 枚举
考场上xjb三分过掉了. 然后$sdfzyhx$.$silvernebula$ $O(n)$虐掉了. 我还是太菜了 #include <cstdio> #include <cmath ...
- JQuery 入门学习附常用UI模块
一.简介 jQuery 库可以通过一行简单的标记被添加到网页中 jQuery 是一个 JavaScript 函数库. jQuery 库包含以下特性: HTML 元素选取 HTML 元素操作 CSS 操 ...
- iOS开发之手势gesture详解(一)
前言 在iOS中,你可以使用系统内置的手势识别(GestureRecognizer),也可以创建自己的手势.GestureRecognizer将低级别的转换为高级别的执行行为,是你绑定到view的对象 ...
- 推荐!手把手教你使用Git(转)
原文出处: 涂根华的博客 欢迎分享原创到伯乐头条 一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放 ...
- 关于xcode 9.0数组问题的遇到的坑
1.最近一直在忙着做项目,今天就来总结最近这段时间遇到的一些比较麻烦的问题.有时候也是颇感无奈. 有句话说的好.人不要总在一棵树上吊死.去旁边那棵树上也可以试试.好了不扯了.直接进入正题吧! 先来阐述 ...
- 微信小程序踩坑之一[wx.request]请求模式
最近在做小程序时,使用wx.request()方法请求时, 当使传输string类型时,一定要声明method请求模式为post,否则会一直报错,而不声明时默认为get, 已填坑 =,= wx.req ...
- 【面试】最容易被问到的N种排序算法!
面试官:小明,是吧?你都知道哪些排序算法,哪几种是稳定排序? 小明:这个我有总结! 关于排序稳定性的定义 通俗地讲就是能保证排序前两个相等的数其在序列的前后位置顺序和排序后它们两个的前后位置顺序相同. ...