什么是mysql子查询及如何运用

发布时间:2020-06-03 17:00:28 作者:三月
来源:PHP中文网 阅读:212

下面讲讲关于什么是mysql子查询及如何运用,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完什么是mysql子查询及如何运用这篇文章你一定会有所受益。 

例:
什么是mysql子查询及如何运用
修改后:
什么是mysql子查询及如何运用

如果将该“select 5000”的子查询语句,替换为“select出来所有商品的平均价”,就具有了现实含义。

在形式上,可以有如下表达:

即可以在这几个位置出现子查询(其中having其实也可以,因为它跟where是一样含义);

子查询,按位置(场合)分:

类型形式
作为主查询的结果数据select c1,(select f1 from tab2) as f11 from tab1; #这里子查询应该只有一个数据(一行一列,标量子查询)
作为主查询的条件数据select c1 from tab1 where c1 in (select f1 from tab2); #这里子查询可以是多个数据(多行一列,列子查询)
作为主查询的来源数据select c1 from (select f1 as c1, f2 from tab2) as t2; #这里子查询可以是任意查询结果(表子查询)

常见子查询

比较运算符中的子查询

形式:

说明:

  select ....  from XXX where  id > 5;

例:

select * from product  where  price = (select  max(price)  from  product );

使用in的子查询

XX  in  (值1,值2,值3,....);
XX  in  (列子查询)

例:

select  *  from  product  where  protype_id  in( 
select  protype_id  from  product_type  where  protype_name  like ‘%电%’
);

使用any的子查询

形式:

操作数 比较运算符 any  (列子查询);

含义:

select  *  from  tab1  where  id >  any  (select  f1  from  tab2);

使用all的子查询:

形式:

操作数  比较运算符 all   (列子查询);

含义:

例:

select  *  from  tab2  where  f1  >  all  ( select  id  from   tab1 );

使用some的子查询

使用exists的查询

形式:

where  exists( 子查询 )

含义:

说明:

因为,exists子查询的该含义,造成主查询往往出现这样的情形:要么全都取出,要么都不取出。如果局限于这个含义(使用情形),其基本就失去了它的现实使用意义。

所以:

实际应用中,该子查询,往往都不是独立的子查询,而是会需要跟“主查询”的数据源(表),建立某种关系——通常就是连接关系。建立的方式是“隐式的”,即没有在代码上体现关系,但却在内部有其连接的“实质”。

例:

结果就:
什么是mysql子查询及如何运用

注意:
- 这种子查询语句,没法“独立存在(独立运行)”,而是必须跟主查询一起使用;
- 其他子查询,是可以独立运行的,而且会得到一个运行的结果。
- 该子查询中的条件,应该设定为跟主查询的某个字段有一定的关联性判断,通常该判断就是这两个表的“本来该有的连接条件”

对于以上什么是mysql子查询及如何运用相关内容,大家还有什么不明白的地方吗?或者想要了解更多相关,可以继续关注我们的行业资讯板块。

推荐阅读:
  1. mysql数据进行子查询
  2. mysql exists子查询

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql 子查询

上一篇:MySQL中行锁、页锁和表锁的实际应用

下一篇:Cglib动态代理是怎么实现的

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》