子查询:又分为where型子查询,from型子查询,exists型子查询这三类。

where型子查询:指把内层查询的结果作为外层查询的比较条件:

举个例子:

我们想查出goods_id最大的商品,要求不能用排序:

select goods_id,goods_name,cat_id,shop_price from goods where goods_id=(select max(goods_id)from goods);

我们还想查出每个栏目下goods_id最大的商品,要求使用where型子查询:

select goods_id,goods_name,cat_id,shop_price from goods where goods_id in (select max(goods_id)from goods group by cat_id);

from型子查询:

内层sql的查询结果当成一张临时表,供外层sql再次查询

举个例子,我们想查询上面那张表中shop_price在20到100之间的商品:

select t1.goods_id,t1.goods_name,t1.cat_id,t1.shop_price 

from(select goods_id,goods_name,cat_id,shop_price from goods where goods_id in (select max(goods_id)from goods group by cat_id)) 

as t1 where t1.shop_price between 20 and 100;

exists 型子查询:

把外层的查询结果拿到内层进行测试,如果内层存在,则输出外层

我们还有一张category表:

我们现在想取出category栏目下有商品的栏目:

select * from category
where exists (select * from goods where category.cat_id=goods.cat_id);

对null的理解:

建表时列后面not null default ''/not null default 0 是什么意思?

答:就是让这个列的值不为nul,就算某个列确实没有填值,也不让它为null

为什么?

答:null是空,它的比较要用到特殊的比较符is null,is not null ,效率不高而且会影响索引效果

左连接:

假设A表在左,不动,有一张B表在A右边滑动,A表与B表之间通过一个关系来筛选B表的行。

A left join B on 条件。 条件为真,则B表中对应的行被取出。

上面的category表有一列cat_name,我们把它跟goods表左连接看看效果:

select goods_id,goods_name,shop_price,goods.cat_id,cat_name
from goods left join category on goods.cat_id=category.cat_id;

我们可以看到category表中的cat_name列与goods表连接在了一起

右连接也是类似,不过处于移植性和兼容性方面考虑,我们通常使用左连接。

我们有两个表t,m:

我们想把它显示为以下的效果:

该怎么做?提示:使用两次左连接

select t1.tname,mres,t2.tname,matime
from m left join t as t1 on t1.tid=m.hid
left join t as t2 on t2.tid=m.gid
where matime between '2006-06-01' and '2006-07-01';

union:

合并两条或多条sql语句的结果

语法:sqlA union sqlB

要求查询价格低于100元和价格高于4000元的商品(不能用or):

(select goods_id,goods_name,cat_id,shop_price from goods where shop_price<100)
union
(select goods_id,goods_name,cat_id,shop_price from goods where shop_price>4000);

使用union时默认去重,如果不想去掉重复数据可以用union all

mysql学习之基础篇06的更多相关文章

  1. mysql学习之基础篇01

    大概在一周前看了燕十八老师讲解的mysql数据库视频,也跟着学了一周,我就想把我这一周所学的知识跟大家分享一下:因为是第一次写博客,所以可能会写的很烂,请大家多多包涵.文章中有不对的地方还请大家指出来 ...

  2. mysql学习之基础篇08 UTF8编码

    这次我们来说一下在Mysql中的编码问题: 我们知道应用于计算机的最早的字符集是ASCII,它所组成的编码是ASCII编码:由于对于其他国家来说它所容纳的字符个数比较少,后来就出现了ANSI字符集,它 ...

  3. mysql学习之基础篇05

    mysql中的统计函数: 1. 查询商品价格中最高的价格: select max(shop_price) from goods; 2. 查询商品价格中最低的价格: select min(shop_pr ...

  4. mysql学习之基础篇04

    五种基本子句查询 查询是mysql中最重要的一环,我们今天就来说一下select的五种子句中的where条件查询: 首先我们先建立一张商品表:goods 由于商品数目太多,我就不一一列举了. 在这里我 ...

  5. mysql学习之基础篇03

    我们今天来进行建表的基本操作: 首先要建表就要了解列类型,因为建表就是声明列的过程,列声明完成了,表也就建好了. mysql中列分为三大类: 一.数值型 数值型又分为整型和浮点型两种. 先来看整型: ...

  6. MySQL学习之基础篇09-事务

    我们在建表的时候通常会在最后声明引擎类型,这次我们就来看看存储引擎都有哪些: 举个例子: --------------------------- 银行转账: 张三想给李四转500元钱: 张三-500 ...

  7. mysql学习之基础篇07

    视图:view 在查询的时候我们经常把查询到的结果当成一张临时表来看,其实view就可以看成一张虚拟表,是表通过某种运算得到的投影 那么如何创建视图?创建视图需要指定视图的列名和列类型吗? 答:不用, ...

  8. mysql学习之基础篇02

    我们来说一下表的增删改查的基本语法: 首先建立一个简单的薪资表: create table salary(id int primary key auto_increment,sname varchar ...

  9. iOS系列 基础篇 06 标签和按钮 (Label & Button)

    iOS系列 基础篇 06 标签和按钮 (Label & Button) 目录: 标签控件 按钮控件 小结 标签和按钮是两个常用的控件,下面咱们逐一学习. 1. 标签控件 使用Single Vi ...

随机推荐

  1. openresty开发系列38--通过Lua+Redis 实现动态封禁IP

    openresty开发系列38--通过Lua+Redis 实现动态封禁IP 一)需求背景为了封禁某些爬虫或者恶意用户对服务器的请求,我们需要建立一个动态的 IP 黑名单.对于黑名单之内的 IP ,拒绝 ...

  2. 2-3 【初识组件】顶部 TabBar

    VsCode中使用Emmet神器快速编写HTML代码 1 根组件下面包含了很多的子组件 组件就是控制屏幕的某一个部分,某一个区域 组件是可以相互包含的 组件是定义在类里面的,类里面有属性和方法 注解会 ...

  3. 【Linux】walle 部署上线单报错:mv: cannot overwrite directory ‘/www’ with non-directory

    错误截图 问题分析:项目设置中. 目标集群部署路径错误, 举例: 假设你 项目名称:laofan 在目标服务器的路径: /www/wwwdata/laofan 那么你在标集群部署路径 就可以写: /w ...

  4. 非LODOP的打印其他问题-简短问答

    该文是一些应用软件,或打印机,即使不使用lodop,也可能会常见的问题.一般和操作系统,电脑硬件打印机硬件等有关. 1.错误-正在打印 怎么解决这个是打印机队列的状态,排查下电脑和打印机的连线是否正常 ...

  5. mysql之各版本rpm包安装

    发现每次想用mysql的rpm包直接安装的时候,都会出现找不到对应的rpm包的情况,故记录一下查找过程 进入官网->downloads->community->mysql commu ...

  6. [LeetCode] 354. Russian Doll Envelopes 俄罗斯套娃信封

    You have a number of envelopes with widths and heights given as a pair of integers (w, h). One envel ...

  7. Python3 列表list合并的4种方法

    方法1: 直接使用"+"号合并列表 aList = [1,2,3] bList = ['www', 'pythontab.com'] cList = aList + bList   ...

  8. tablespace表空间

    tablespace——表空间,便于理解,把oracle数据库看作一个实在房间,表空间可以看作这个房间的空间,是可以自由分配,在这空间里面可以堆放多个箱子(箱子可以看作数据库文件),箱子里面再装物件( ...

  9. Maven中解决jar包冲突的三种方式

    首先我们在idea中创建一个maven工程,我们只关注pom.xml以及External Libraries中导入的jar包 导入spring-beans.jar <dependency> ...

  10. 深入浅出JVM(一):运行时数据区域

    程序计数器 线程私有 指向了正在执行的虚拟机字节码指令的地址:如果是本地方法,数值为空 没有 OutOfMemoryError 错误的区域 Java虚拟机栈 线程私有: 生命周期与线程相同: 代表着 ...