mysql联合查询怎么加子查询吗_mysql学习之路_联合查询与子查询

联合查询:将多次查询(多条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学习之路_联合查询与子查询

标签:union   不同   nio   mysql学习   出现   要求   from   mit   联合

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:https://www.cnblogs.com/lqh969696/p/9765540.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值