联合查询

联合查询:将多次查询(多条select语句)在记录上进行拼接(字段不会增加)。

语法:多条select语句构成,每条select语句获取的字段必须严格一致(但是字段类型无关)。

Select 语句1

Union [union选项]

Select语句2........

Union 选项有两个

All:保留所有

Distinct:去重。默认的

联合查询只要求字段一样,与数据类型无关。

意义:两种

1,查询一张表但是需求不同。

2,多表查询,多张表的结构完全一样,保存的数据也一样

Order by

使联合查询中order by 不能直接使用需要对查询语句使用括号。

例:

(select * from my-class where sex=’男’ order by age asc limit 999)

Union

(select * from my-class where sex=’女’ order by age desc limit 999);

若要order by生效,必须搭配limit ,limit最大值。

 子查询

子查询:subquery 查询是在某个查询结果之上进行的(一条select语句含另一条select语句)

子查询分为两种:按位置分,按结果分

按位置分类:子查询select语句在外部查询

Select语句出现的位置

Form子查询:子查询跟在form后面。

Where 子查询:子查询出现在where条件中

Exists子查询:子查询出现在exists里面

按结果分类:根据子查询得到的数据进行分类(理论上讲任何一个查询得到的结构都可以理解为二维表)

标量查询:子查询得到的结果是一行一列

列子查询:子查询得到的结果是一行多列

行子查询:子查询得到的结果是一行多列(多行多列)

表子查询:子查询得到的结果是多行多列(出现位置在form之后)

标量子查询

例:需求:知道名字php获取学生

Select *from my_class where c_id =(select id from my_student where c_name=php);

列子查询

例:需求查询所有在读班级的学生(班级表存在的班级)

1,确定数据源:学生

Select * from my_sutdent where c_id in (?)

2,确定有效班级id,所有班级id

Select id from my_class;

合:Select * from my_sutdent where c_id in (Select id from my_class);

列子查询返回的结果比较:一行多列,需要使用in作为条件匹配,其实mysql还有几个类似:all ,some,any===in;

行子查询:

行子查询返回的结果可以是多行多列(一行多列)、

例:需求:要求查询整个学生中年龄最大,身高最高的学生

1,确定数据源

Select *from my_student where age =? and heigth=?;

2,确定最大的年龄和最高的身高

Select max(age),max(height) from my_student;

行子查询:需要构造行元素,行元素多个字段构成

Select * from my_student where (age,height)=(select max(age),max (height)from my_student);

表子查询:

表子查询:子查询返回的结果是多行多列的二维表,子查询的结果当做二维表来使用

例:需求:找出每班最后一个的学生

1,确定数据源;先将学生安装身高进行降序或者是升序

Select *from my_student order by height desc ;

2,从每个班选出第一个学生

Select * from my_student group by c_id;

表子查询:from子查询得到的结果作为from的数据源。

Exists 子查询

Exists 是否存在,exists子查询就是用来判断某些条件是否满足(跨表)exists是接在where之后,exists返回的结果只有0和1

例:查询所有的学生,前提条件是班级存在

1,确定数据源

Select *form my_student where?

2,确定条件是否满足

Exists (select * from my_class)--是否成立

mysql学习之路_联合查询与子查询的更多相关文章

  1. mysql学习之路_视图

    视图 视图:view是一种有结构的但是没有结构来源的虚拟表,虚拟表的结构来源不是自己定义的而是从对应的基表中产生(来源) 创建视图 基本语法: Create view 视图名字 as select 语 ...

  2. mysql学习之路_连接查询

    回顾 列属性:主键,自增长,唯一键. 关系:一对一,一对多,多对多 三层范式: 1NF:字段设计必须符合原子性 2NF:不存在部分依赖(没有复合主键) 3NF:不存在传递依赖(实体单独成表) 逆规范化 ...

  3. mysql学习之路_事物_存储过程_备份

    数据备份与还原 备份:将当前已有的数据保留. 还原:将已经保留的数据恢复到对应表中 为什么要做数据备份 1,防止数据丢失,被盗,误操作 2,保护数据记录 数据备份还原方式有多种:数据表备份 单表数据备 ...

  4. mysql学习之路_高级数据操作

    关系 将实体与实体的关系,反应到最终数据表的设计上来,将关系分为三种,一对多,多对多,多对多. 所有关系都是表与表之间的关系. 一对一: 一张表的一条记录一定只对应另外一张表的一条记录,反之亦然. 例 ...

  5. mysql学习之路_外键

    回顾4 连接查询: 连接多张表到一起,不管记录数如何,字段数一定会增加. 分类:内连接,外连接.自然连接,交叉连接, 交叉连接:cross join (笛卡尔积) 内连接:inner join,左右两 ...

  6. mysql学习之路_字段类型与属性2

    字段属性: 主键,唯一键,自增长. 主键: Primary key 主要的键,一张表只能有一个字段能使用对应的键,用来唯一约束该字段里面的数据不能重复,称之为主见. 一张表最多只有一个主键. 增加主键 ...

  7. mysql学习之路_基础知识

                    Mysql php阶段将数据库分为三个阶 基础阶段: mysql数据库的基本操作(增删改查),以及一些高级操作(视图,触发器,函数,存储过程等),PHP操作没有sql数 ...

  8. mysql学习之路_字段类型与属性

    回顾 数据库基本知识:关系型数据库与非关系型数据库 关系型数据库:安全(磁盘) 非关系型数据库:高效(内存) 关系型数据库:建立在关系模型上的数据库, 数据结构:二维表(浪费空间) 数据库操作指令:s ...

  9. mysql学习之路_乱码问题

    中文数据问题: 中文数据问题本质就说字符集问题, 计算机只识别二进制,人类识别符号:需要友谊个二进制与字符对应关系(字符集). 报错:服务器没有识别对应的四个字节. 服务器认为的数据是utf—8,一个 ...

随机推荐

  1. springmvc控制器传可变路径

    @RequestMapping("/clone{path}") public String cloneModules(HttpServletRequest req,@PathVar ...

  2. zookeeper 单机版配置

    zookeeper :中间件,为分布式系统进行协调服务 作用于分布式系统,可以为大数据服务 支持java 和 C 客户端的api zookeeper 特性:一致性,数据会按照顺序分批入库: 原子性:数 ...

  3. 在BCH硬分叉后防止重放攻击-2

    重放攻击原理和防范措施——如何安全分离BCH的分来源:巴比特018-11-18 16:49:37 热度 12390 第0章 引言 即将面临的比特币分裂,如何保证你的币在分裂后肯定留下两种币?一个重点要 ...

  4. IDEA安装小配置

    1. view-->toolbar+toolbuttons 2. 根据大小写IDEA能准确提示 配置自动导入包 定义代码模板 提示忽略大小写 配置虚拟机内存,修改idea64.exe.vmopt ...

  5. c#启动windows服务问题总结

    程序以管理员权限运行的原因 在Vista 和 Windows 7 及更新版本的操作系统,增加了 UAC(用户账户控制) 的安全机制,如果 UAC 被打开,用户即使以管理员权限登录,其应用程序默认情况下 ...

  6. angular2.0学习笔记4.npm常用指令记录及angular语法

    以下命令,都需要在命令行窗口中,先切入到项目文件夹目录,再执行 1.npm start 这个命令会在“监听”模式下运行TypeScript编译器,当代码变化时,它会自动重新编译. 同时,该命令还会在浏 ...

  7. (转)silverlight应用程序中未处理的错误代码:2104 类别:InitializeError

        解决方案:第一步:默认网站--属性-----http头 第二步:点击mime类型: 第三步:点击新建: 第四步:输入扩展名以及类型: (1) 扩展名:.xaml MIME类型:applicat ...

  8. kafka的advertised.host.name参数 外网访问配置

    kafka的server.properties文件 ```host.name```开始只绑定在了内部IP上,对外网卡无法访问. 把值设置为空的话会kafka监听端口在所有的网卡上绑定.但是在外网访问时 ...

  9. Linux设置桌面图标 (双击运行jar包)

    Ubuntu平台 预备条件: 1)平台是Gridion上的Ubuntu 2)安装了JRE (版本如下) 3)在IDE(我用的是IDEA)打包成可运行的jar文件 设置步骤: 1)新建.desktop文 ...

  10. ApplicationContext(四)BeanFactory 功能扩展

    ApplicationContext(四)BeanFactory 功能扩展 上节我们提到容器刷新的第二步初始化 BeanFactory 工厂并解析配制文件,但此时 BeanFactory 的功能还很简 ...