子查询

在開始了解子查询之前,首先做下准备工作,建立3个表,

  • 一个是customers表,当中包含:客户名字、客户ID、客户Tel等。
  • 一个是orders表,当中包含:订单号、客户ID、订单时间等。

  • 一个是ordersitems表,当中包含:订单物品、订单号、物品数量。

准备工作

1、建表

建customers表的命令例如以下,其他的表与之相似:

  1. create table customers(cust_name varchar(10),cust_id int(10),cust_tel varchar(10));

2、插入内容

为customers表插入内容的命令例如以下,其他的与子相似:

  1. insert into customers values('wu',2,'1387234');

最后三个表的内容截图例如以下:

子查询

前面我们所学的东西都是简单的查询,即从单个数据库表中检索数据的单条语句。

究竟什么是子查询呢?通过以下这个样例,相信我们就更好的理解了。

上面我们建了三个表,分别为customers/orders/ordersitems.

如今,假如,我们想看下订购了物品 apple的全部客户信息,应该如何检索呢?

以下列出详细的步骤:

  • 第一步:在ordersitems表中找出包含有apple的订单号order_id.
  • 第二步:依据上一步查找的结果,找出订单号为order_id的客户ID(cust_id).
  • 最后:依据上一步查找的结果,在customers表中依据客户ID(cust_id)找出客户信息。

如今我们依照步骤来查询下,观察下结果:

从上面能够看出,我们就是依照步骤,将第一步的结果当做第二步的条件来进行查询。将第二步的结果直接作为第三步的条件来进行查询,最后得到终于的结果。

如今,我们分别把第一个子查询(返回订单号的那一个)变为子查询组合到第二个查询中。

第一个查询的代码例如以下:

  1. select order_id from ordersitems where content='apple';

作为子查询组合到第二个查询后的代码例如以下:

  1. select cust_id from orders where order_id in (
  2. select order_id from ordersitems where content='apple'
  3. );

结果例如以下,从结果能够看出。与我们单个查询的结果是一致的:

如今。我们就把上面的查询作为子查询组合到第三个查询中。代码例如以下:

  1. select cust_name,cust_tel from customers where cust_id in(
  2. select cust_id from orders where order_id in(
  3. select order_id from ordersitems where content='apple')
  4. )
  5. );

注意:包含子查询的select语句难以阅读和调试。特别是他们较为复杂时。如上所看到的把子查询分解为多行而且适当地进行缩进,能极大地简化子查询的使用。

在where子句中使用子查询能够编写出功能非常强而且非常灵活的SQL语句。对于能嵌套的子查询的数目没有限制,只是在实际使用时因为性能的限制,不能嵌套太多的子查询。

注意:在子查询中。列必须匹配

作为计算字段使用子查询

上面介绍的都是作为条件使用子查询。以下就介绍下作为计算字段使用子查询。

还是以一个样例来进行说明。

假如须要显示customers表中每一个客户的订单总数。

为运行这个操作,过程例如以下:

  • 从customers表中检索客户列表
  • 对于检索出的每一个客户。统计其在orders表中的订单数目。

比如:查询客户id=1的订单数的命令例如以下:

  1. select count(*) as order_total from orders where cust_id=1;

将上面的命令作为字段的子查询的代码例如以下:

  1. select cust_name,cust_tel,(select count(*) from orders where orders.cust_id==customers.cust_id) from customers ;

小结

子查询能够理解为嵌套,这里方便理解一点。可是在我们使用子查询的过程中。要先分步骤来完毕,然后将子查询一个一个的组合起来,直到这个子查询增加之后得到的结果是符合要求的。然后继续将下一个子查询组合进行直至完毕全部的子查询都全部正确的增加。

《MySQL必知必会学习笔记》:子查询的更多相关文章

  1. 《MySQL必知必会》学习笔记——前言

    前言 MySQL已经成为世界上最受欢迎的数据库管理系统之一.无论是用在小型开发项目上,还是用来构建那些声名显赫的网站,MySQL都证明了自己是个稳定.可靠.快速.可信的系统,足以胜任任何数据存储业务的 ...

  2. 《MySQL必知必会》学习笔记整理

    简介 此笔记只包含<MySQL必知必会>中部分章节的整理笔记.这部分章节主要是一些在<SQL必知必会>中并未讲解的独属于 MySQL 数据库的一些特性,如正则表达式.全文本搜索 ...

  3. MySQL必知必会(第4版)整理笔记

    参考书籍: BookName:<SQL必知必会(第4版)> BookName:<Mysql必知必会(第4版)> Author: Ben Forta 说明:本书学习笔记 1.了解 ...

  4. MySQL必知必会1-20章读书笔记

    MySQL备忘 目录 目录 使用MySQL 检索数据 排序检索数据 过滤数据 数据过滤 用通配符进行过滤 用正则表达式进行搜索 创建计算字段 使用数据处理函数 数值处理函数 汇总数据 分组数据 使用子 ...

  5. 《SQL必知必会》学习笔记二)

    <SQL必知必会>学习笔记(二) 咱们接着上一篇的内容继续.这一篇主要回顾子查询,联合查询,复制表这三类内容. 上一部分基本上都是简单的Select查询,即从单个数据库表中检索数据的单条语 ...

  6. 《mysql必知必会》读书笔记--存储过程的使用

    以前对mysql的认识与应用只是停留在增删改查的阶段,最近正好在学习mysql相关内容,看了一本书叫做<MySQL必知必会>,看了之后对MySQL的高级用法有了一定的了解.以下内容只当读书 ...

  7. 《SQL必知必会》学习笔记整理

    简介 本笔记目前已包含 <SQL必知必会>中的所有章节. 我在整理笔记时所考虑的是:在笔记记完后,当我需要查找某个知识点时,不需要到书中去找,只需查看笔记即可找到相关知识点.因此在整理笔记 ...

  8. MySQL必知必会复习笔记(1)

    MySQL必知必会笔记(一) MySQL必知必会是一本很优秀的MySQL教程书,并且相当精简,在日常中甚至能当成一本工作手册来查看.本系列笔记记录的是:1.自己记得不够牢的代码:2.自己觉得很重要的代 ...

  9. mysql学习--mysql必知必会1

     例如以下为mysql必知必会第九章開始: 正則表達式用于匹配特殊的字符集合.mysql通过where子句对正則表達式提供初步的支持. keywordregexp用来表示后面跟的东西作为正則表達式 ...

  10. mysql学习--mysql必知必会

      上图为数据库操作分类:     下面的操作參考(mysql必知必会) 创建数据库 运行脚本建表: mysql> create database mytest; Query OK, 1 row ...

随机推荐

  1. gulpfile.js备份

    var gulp = require('gulp'); var uglify = require('gulp-uglify'); // var rename = require('gulp-renam ...

  2. chef and churu 分块 好题

    题目大意 有一个长度为n的数组A 有n个函数,第i个函数 \[f(l[i],r[i])=\sum_{k=l[i]}^{r[i]}A_k\] 有两种操作: 1)修改A[i] 2)询问第x-y个函数值的和 ...

  3. A* k短路 学习笔记

    题目大意 n个点,m条边有向图,给定S,T,求不严格k短路 n<=1000 m<=100000 k<=1000 不用LL 分析 A*算法 f(i)表示从S出发经过i到T的估价函数 \ ...

  4. DispatcherServlet与ContextLoaderListener的对比

    1. 从DispatcherServlet和ContextLoaderListener的初始化过程可以看出,二者分别会生成一个WebApplicationContext,且以不同的attrName注册 ...

  5. TroubleShoot:网站设置找不到术语管理

    在SharePoint站点中找不到“术语管理”这个链接功能. 解决方案: Enable-SPFeature -id “73EF14B1-13A9-416b-A9B5-ECECA2B0604C” -Ur ...

  6. Introduction to the WinPcap Networking Libraries

    Introduction to the WinPcap Networking Libraries use wire shark or fiddler

  7. 30深入理解C指针之---字符串和数组

    一.字符串与数组 1.定义:使用字符数组表示字符串 2.特征: 1).可以直接使用字符串字面量初始化字符数组 2).声明后,赋值就只能使用字符串操作函数strcpy函数赋值 3).可以使用数组的一一赋 ...

  8. Linux 之 Redis

    Linux 之 Redis 参考教程:[千峰教育] 一.Redis简介: 说明: 1.也是一种类似于Memcached的key-value机制的存储服务 2.是非关系型数据库(NoSQL)的一种 3. ...

  9. Codeforces Gym101572 G.Galactic Collegiate Programming Contest (2017-2018 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2017))

    Problem G Galactic Collegiate Programming Contest 这个题题意读了一会,就是几个队参加比赛,根据实时的信息,问你1号队的实时排名(题数和罚时相同的时候并 ...

  10. Codeforces 401D Roman and Numbers

    题目大意 Description 给定一个数 N(N<1018) , 求有多少个经过 N 重组的数是 M(M≤100) 的倍数. 注意: ①重组不能有前导零; ②重组的数相同, 则只能算一个数. ...