首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL数据高级查询之连接查询、联合查询、子查询

大家好,又见面了,我是你们的朋友全栈君。 一、连接查询 1、交叉连接:CROSS JOIN 把表A和表B的数据进行一个NM的组合,即笛卡尔积。...: 在查询数据的时候,不同表有同名字段,这个时候需要加上表名才能区分, 而表名太长, 通常可以使用别名....跟数据类型无关 SELECT * FROM t1 UNION all SELECT * FROM t2 联合查询的意义: 查询同一张表,但是需求不同: 如查询学生信息, 男生身高升序, 女生身高降序...多表查询: 多张表的结构是完全一样的,保存的数据(结构)也是一样的....子查询: 子查询出现where条件中 Exists子查询: 子查询出现在exists里面 按结果分类: 根据子查询得到的数据进行分类(理论上讲任何一个查询得到的结果都可以理解为二维表) 标量子查询

6.2K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    3.4 《数据库系统概论》之数据查询—SELECT(单表查询、连接查询、嵌套查询、集合查询、多表查询)

    文章目录 0.前言 1.思维导图 2.Student/SC/Course表数据及结构 3.SELECT语句的一般格式 4.单表查询 (1)选择表中的 ① 查询指定列 ② 查询全部列 ③ 查询经过计算的值...7.集合查询 (1) 集合操作的种类 (2)集合操作举例 ---- 0.前言 本篇文章是对《数据库系统概论》王珊老师主编的数据库查询SELECT部分做的笔记,采用的是SQL Sever 数据库。...本篇文章中所有的例子,都会有结果的截图进行验证。 书上的结果和在机器上的结果可能略有不同,可能是数据库版本或软件显示的问题,或者是教材需要升级改版了。...谓词 存在量词 ∃ 带有EXISTS谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”。...(1) 集合操作的种类 并操作UNION 交操作INTERSECT 差操作EXCEPT 参加集合操作的各查询结果的列数必须相同;对应项的数据类型也必须相同 (2)集合操作举例 [例48] 查询计算机科学系的学生及年龄不大于

    6.1K20

    数据库,单表查询,多表查询,子查询

    数据库查找方式进阶 一.单表查询 1.查看表单选择段落 1.disinct 所有内容去重:select disinct * from 表名称; 指定字段去重:select disinct 字段 from...B,用,连接表示具有相同字段A以及相同字段B进行分组 having 判断内容 注意: having 必须分组后才能使用 分组后只能用having group_concat(字段),可以把由于分组后造成的折叠内的数据全部显示...对于多页操作 分页原理:先查询总数据条数 设为a 确定每页数量b 总页数为c = a / b 如果除不尽则需要加1 例如 10 / 3 正确页数为4 查询语句的起始位置为s = 当前页数d 减去...1.笛卡尔积查询 语法:select *from 表1,表2 他会把多个表每行与另外个表统统匹配上,其中会有一些脏数据,我们可以用里面值的关系进行连接 2.内连接查询 其本质就是笛卡尔积查询 区别是把,...by dept_id having avg(age) > 25); "多表查询方式: 先把数据拼接到一起 在加以筛选" select dept.name from emp inner join dept

    5.3K40

    MySQL数据库——多表查询之内连接查询、外连接查询、子查询

    1 多表查询 1.1 多表查询概述 多表查询就是从多个表中进行数据的查询操作,语法:select  列名列表 from 表名的列表  where......】:SELECT *FROM dept,emp; 从查询结果中可以看到共计15条数据,这个查询结果叫做笛卡尔积,如查询2个表,每个表中的数据条数分别为A,B,则查询的结果条数就是A*B;但是看如下结果,...1.2 多表查询的分类 1.2.1 内连接查询 1)隐式内连接:使用where条件来消除无用的数据; -- 查询所有员工信息和对应的部门信息 SELECT *FROM emp,dept WHERE emp...`id`; 3)内连接查询注意事项: 从哪些表中查询; 条件是什么; 查询哪些字段; 1.2.2 外连接查询 1)左外连接:查询的是左表所有的数据及其交集部分。...2)右外连接:查询的是右表所有的数据及其交集部分。

    11.8K10

    MySQL数据查询之多表查询

    #多表连接查询语法(重点) SELECT 字段列表 FROM 表1 INNER|LEFT|RIGHT JOIN 表2 ON 表1.字段 = 表2.字段; 1 内连接查询 (只显示符合条件的数据...(显示左右表中全部数据)   全连接查询:是在内连接的基础上增加 左右两边没有显示的数据   注意: mysql并不支持全连接 full JOIN 关键字   注意: 但是mysql 提供了 UNION...:UNION 会去掉重复的数据,而 UNION ALL 则直接显示结果 示例 复制条件多表查询 1....子查询(嵌套查询): 查多次, 多个select 注意: 第一次的查询结果可以作为第二次的查询的 条件 或者 表名 使用....注:插入数据时,先插入主表中的数据,再插入从表中的数据。 删除数据时,先删除从表中的数据,再删除主表中的数据。

    8.2K20

    SQL 数据查询(4)—— 嵌套查询

    文章目录 带有IN谓词的子查询 带有比较运算符的子查询 带有ANY(SOME)或ALL谓词的子查询 带有EXISTS谓词的子查询 型如下面这样的就是嵌套查询: SELECT Sname FROM Student...IN谓词的子查询 IN谓词用于子查询结果是一个集合的情况 例3.55:查询与“刘晨”在同一个系学习的学生 先分步用单表查询做 第一步: SELECT Sdept FROM Student WHERE...,将得到的值代替内层查询 执行外层查询 带有ANY(SOME)或ALL谓词的子查询 >ANY 大于子查询结果中的某个值 >ALL 大于子查询结果中的所有值 查询结果中的某个值 查询结果中的所有值 >=ANY 大于等于子查询结果中的某个值 >=ALL 大于等于子查询结果中的所有值 查询结果中的某个值 查询结果中的所有值 =ANY...效率高 带有EXISTS谓词的子查询 EXISTS代表存在量词,带有EXISTS的子查询不返回任何数据,只产生true和false两个值 例3.60:查询所有选修了1号课程的学生姓名 SELECT Sname

    1.3K20

    数据库-多表查询-连接查询

    数据库-多表查询-连接查询 同时查询多张表获取到需要的数据 比如:我们想查询到开发部有多少人,需要将部门表和员工表同时进行查询 多表查询的分类: 准备数据 -- 创建部门表 create table...笛卡尔积 概念 左表的每条数据和右表的每条数据组合成新的数据 如:查询员工表和部门表,查询的数据如下,结果就是笛卡尔积的数据 select * from emp,dept; 1566353721827...= 部门表.id 的数据才是有效的 确定查询条件,我们查询的是唐僧的信息,员工表.name='唐僧' 确定查询字段,查询唐僧的信息,显示员工id,姓名,性别,工资和所在的部门名称 我们发现写表名有点长...使用右外连接查询: 基于右连接查询,不管 emp 的数据有没有关联 dept_id, 也可以查询出右表中的所有数据 mysql> select * from dept d right join emp...联合查询 Union (Mysql 支持) Mysql 为了查询所有表的关联数据,可以将左右连接的查询 联合一起来执行。

    13.5K20

    SQL数据查询之——嵌套查询

    一、概念描述 在SQL语言中,一个 SELECT-FROM-WHERE 语句称为一个查询块。将一个查询块嵌套在另一个查询块的 WHERE 子句或 HAVING 短语的条件中的查询称为 嵌套查询。...二、带有IN谓词的子查询 在嵌套查询中,子查询的结果往往是一个集合,所以谓词 IN 是嵌套查询中最经常使用的谓词。...其语义如下: >ANY 大于子查询结果中的某个值 >ALL 大于子查询结果中的所有值 查询结果中的某个值 查询结果中的所有值 >=ANY 大于等于子查询结果中的某个值 >...=ALL 大于等于子查询结果中的所有值 查询结果中的所有值 查询结果中的某个值 =ANY 等于子查询结果中的某个值 =ALL 等于子查询结果中的所有值(通常没有实际意义...五、带有 EXISTS 谓词的子查询 带有EXISTS 谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”。

    2.2K30

    Mysql数据库--聚合查询、分组查询、联合查询(不同的连接方式)

    1.查询的进阶版 1.1查询搭配插入进行使用 我们首先创建两张表,一个叫做student,一个叫做student2,两个表都是只有这个int和varchar 的数据类型,这个时候,我们向这个第一个表里面直接使用这个...insert插入数据,但是这个时候student2这个表还是空的; 我们查询这个student这个表里面插入的内容: 把这个查询的结果直接插入到我们的这个student2这个表里面去:这个实际上就是把两个步骤合成了一步...,下面我们会依次去演示这个例如count,sum,min,max的用法; 首先还是要创建一张表,然后向这个表里面插入一些数据,例如下面的这个所示,我下面的这个演示也是基于下面的这个表进行的: 下面的这个就是聚合查询里面的这个...count的使用,我们可以使用这个count计算这个数据的行数,虽然我们通过这个select好像是可以看到这个数据的行数的,但是这个是客户端,当我们在这个服务器里面通过代码来操作的时候,我们是看不到这个信息的...,max,avg这样的函数,进行一些数据的处理:下面的这个就是求出来某一门科目的这个最大值,最小值,以及平均值的SQL语句,其实也不是很困难; 1.3group by分组查询 我们的操作还是基于这个表来完成的

    25510

    MySQL 查询数据

    MySQL 数据库使用SQL SELECT语句来查询数据。 你可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过 Python来查询数据。...语法 以下为在MySQL数据库中查询数据通用的 SELECT 语法: SELECT column_name,column_name FROM table_name[WHERE Clause][LIMIT...你可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0。...该函数用于执行 SQL 命令,然后通过 Python 的函数 fetch() 来使用或输出所有查询的数据。 fetchall() 函数从结果集中取得所有数据。...注:小编已经抓取所有盗墓笔记的章节目录与链接,储存在学习使用的远程mysql数据库中,如需使用远程数据库或者单独创建个人使用的数据库请后台联系小编或者后台回复mysql 抓取的数据存储在dmbj的dmbj

    6.7K60

    pymysql查询数据

    我们可以用fetchone来获取一行数据,也可以用fetchall来获取多条数据 在查询数据时,我们可以把指针设置为DictCursor,那么返回的就是一个字典,方便处理。...注意的是,fetchone和fetchall都是返回当前指针位置以后的数据,也就是说,不会返回指针位置之前的数据。 我们可以通过scroll方法来移动指针。...scroll方法有两个模式:absolute和relative 显然absolute模式就是以绝对位置来移动指针,0是第一条数据的位置。...看看下面这段代码,当第一次输出完所有的数据之后,再次执行fetchall,输出的是空列表,只有当指针的位置移动到0之后,才会输出完整的列表。...#查询数据 import pprint import pymysql host = 'localhost' username = 'test' password = 'test' db_name =

    1.1K20

    SQL语句 之 数据查询(二)多表查询—————–数据查询的重点 难点「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 1.0 连接查询—多表查询 数据库已有的表和里面的内容 1. 等值连接与非等值连接 什么叫等值连接呢?...student中每一个Sno 的值与sc表的第一个元素比较 等student.Sno 的值都与Sc.sno 第一个值比较完成后,在与下一个值比较,以此类推 满足条件就是一行 为了满足接下来的例子 插入数据后的三张表如下...通常的连接只会输出满足条件的连接 不满足的不会输出 例如上面的自然连接的例子中 学号为002的学生并没有显示出来 因为他不符合要求,左连接就是保留左边表的左右数据,连接的表如果没有就是null...= ‘xyd’; 这就涉及到数据库调优的知识了,由于嵌套查询的调优技术还没有成熟,所以我们能用连接查询就用连接查询 2....看下表: 使用 any或者all的时候必须配合比较运算符 并且有的数据库不用any 用some 谓词 解释 >any 大于子查询结果集中的某个值 >all 大于子查询结果集中的所有值 查询结果集中的某个值

    1K20

    sql镶嵌查询_SQL数据查询之——嵌套查询「建议收藏」

    将一个查询块嵌套在另一个查询块的 WHERE 子句或 HAVING 短语的条件中的查询称为 嵌套查询。...二、带有IN谓词的子查询 在嵌套查询中,子查询的结果往往是一个集合,所以谓词 IN 是嵌套查询中最经常使用的谓词。...其语义如下: >ANY 大于子查询结果中的某个值 >ALL 大于子查询结果中的所有值 小于子查询结果中的某个值 小于子查询结果中的所有值 >=ANY 大于等于子查询结果中的某个值 >=ALL 大于等于子查询结果中的所有值...<=ALL 小于等于子查询结果中的所有值 <=ANY 大于等于子查询结果中的某个值 =ANY 等于子查询结果中的某个值 =ALL 等于子查询结果中的所有值(通常没有实际意义) !...,SageFROMStudentWHERE Sage ‘CS’; 五、带有 EXISTS 谓词的子查询 带有EXISTS 谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”

    2K10

    sql中的嵌套查询_sql的多表数据嵌套查询

    , 因为测试的时候是一天中的两条数据, 没有不同的日期,所以当日以为是正确的 ,然而第二天写入数据了,要取出数据,却发现没有数据, 返回空的行, 以为都是代码又有问题 了,找了半天都没有 ,仔细看看了存储过程中的代码...,发现这样返回的数据的确是空的。...这个是嵌套查询的语句。 先执行的是外部查询的语句 。 比如说有三条信息.用上面写的语句在SQL分析器中执行 分析下这样的查询 先查找的是 日期 , 日期最大是下面两条语句 。 在对比时间 。...发现时间最大的只有一 条数据, 这样第二条数据就理所当然的被取出来了。 这个是当时测试的结果 但后来我修改了数据 。第二天测试发现,数据为空了。 没有数据 。...分析是这样的 查询到的最大天数是2013-03-18这条数据。第三行。 而时间最带的是21:12:21 是第二条数据 这样与的结果就是没有交集,为空了。 后来通过 查找课本和询问他人。

    7.1K40

    sql嵌套查询例子_sql的多表数据嵌套查询

    大家好,又见面了,我是你们的朋友全栈君。 查询学生上课人数超过 “Eastern Heretic” 的任意一门课的学生人数的课程信息,请使用 ANY 操作符实现多行子查询。...: 第一层的父查询为在课程表 courses 中查询满足条件的全部课程信息,这个条件由子查询来完成,即为,查询学生上课人数超过 ”Eastern Heretic“ 的任意一门课的学生人数。...这一部分的子查询中需要结合 ANY 操作符实现。之后,再将子查询进行拆分,形成第二层的嵌套子查询。...第二层的父查询为在课程表 courses 中根据教师 id 查询学生上课人数, 其子查询为在教师表 teachers 中查找教师名 name 为 “Eastern Heretic” 的教师 id。...= 但是有些数据库会报错,例如SQL2000 —-- AND `teacher_id` ( SELECT `id` FROM `teachers` WHERE `name` = 'Eastern

    3.1K20
    领券