专注WEB开发 分享经验,沉淀知识

有哪些常见的mysql子查询

 作者:chenxing  时间:2017-02-09 15:42  阅读:114  评论:

和in()的比较,二者的使用场景差不多。子查询表大则用exists(内层索引),子查询表小则用in(外层索引)。

在php做一些项目时,真正用到的子查询并不多,涉及复杂的查询,一般都在php中对复杂的查询进行拆分。因此,很php开发者对子查询并不熟悉。

下面,我对mysql常见的子查询知识点做些梳理,供大家参考:

1.where型子查询:把内层查询当作外层查询的比较条件

形如:


select * from goods where goods_id = (select max(goods_id) from goods);

注意: where后面 = in all 或者any等不通关键词子查询返回值也要相对应,如 ‘=’一般返回的是单行单列的数据。

2.from型子查询:把子查询当作一张临时表,对这张临时表在做查询

形如:(本sql取自近期的一个php项目)


SELECT COUNT(*) as loginnum FROM (SELECT COUNT(*) FROM `{$tableName}` WHERE device_id = {$param['id']} {$between} GROUP BY user_id) AS co;

注意: 必须给这个子查询临时表取别名 AS 'name'; 一定别忘了加AS取别名

3.exists型子查询:子查询就是对外层表进行循环,再对内表进行内层查询 形如:


 select cat_id,cat_name from category where exists(select * from goods where goods.cat_id = category.cat_id);

注意: 和in()的比较,二者的使用场景差不多。子查询表大则用exists(内层索引),子查询表小则用in(外层索引)。

除特别注明外,本网站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/31.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

一年时间又回到这里

 2019-07-27 16:54  177

PHP字符串转数组的三种场景

 2018-05-05 01:32  217

PHP如何遍历字符串?

 2018-05-04 00:56  1444

api接口常见的安全问题和解决方案

 2018-05-03 23:20  1051

 最新评论

 lisheng: 05月09日 19:26
兴哥牛B加油哈兴哥成功的道路上你又进了一步 哈哈
来源: 一年时间又回到这里
 心态炸裂: 03月24日 10:54
No3.blindcomfirm 多了一个l,望改正!!!
来源: 微信小程序获取input值的总结
 666666: 11月08日 13:49
66666
来源: 一年时间又回到这里
 花花草草: 10月14日 14:58
tp5不是已经提前开了吗
来源: _SESSION变量未定义?
 疯了: 10月10日 13:40
你好呀,我使用docker构建的 把整个项目给了777 并把runtime的所有者给了nginx php的运行者还是报错
来源: thinkphp5的mkdir() Permission denied问题探讨
 mesecretme: 09月30日 15:30
有个问题,有没有发现用redis保存session的话,session清空redis的key还没过期,会依然保留的,这是值变成空了
来源: php项目redis实现session共享案例