所谓子查询语句,就是先通过一个语句来查询出一个结果,然后再通过一个查询语句从这个结果中再次查询。子查询语句一般有以下3种。下面以一个案例来做讲解。

案例:查询【例1】中每个分类下的最新的那一条商品信息。

如果通过单句查询,是获取不到的。如下面这样是错误的:

select max(goods_id),cat_id,goods_name from goods group by cat_id;

这样获取到了每个分类的最新商品ID号goods_id,但是其它信息如goods_name商品名称却是旧的那一条。所以,要想获取到每个分类的最新商品信息,要么分开语句查询,要么用子查询。

1:where子查询语句。

select * from goods where goods_id in ( select max(goods_id) from goods group by cat_id);

这句代码,我们先用group by查询出每个分类的最新的商品ID,然后通过where...in () 条件语句查询出每个分类最新商品ID 的商品的信息。这里是把group by语句作为where的子查询语句。

2:from子查询语句。

select * from (select * from goods order by cat_id,goods_id desc) as gk group by cat_id;

From子查询就是把 select查询到的结果作为一张表,如上面加粗的代码。注:必须把select查询到的结果集 取一个别名,如上面代码中的红色部分。否则会报错。

这样,我们同样查询出了每个分类下最新商品的信息。

3:exists子查询语句:

题目:查询【例1】哪些栏目下有商品。分类表名:category

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

上句中的exists排查了(当商品表中的分类ID=分类表中的分类ID)时,有没有商品。如果有,就再查询这个分类的信息,如查没有,就排除这个分类。最后结果就是,查询出了有商品的商品分类信息。

嗯,这里我们介绍了3种比较常用的mysql数据库子查询语句:where子查询语句、from子查询语句、exists子查询语句。当然,如果你不想使用子查询语句,也可以把它们拆分成2个语句来执行,效果也是一样的。

转载:http://wanlimm.com/77201808176609.html

最新文章

  1. Android 显示 WebView ,加载URL 时,向webview的 header 里面传递参数
  2. [转载]百度编辑器-Ueditor使用
  3. openresty(nginx)、lua、drizzle调研
  4. VS2012如何更新下载TFS上面的代码到本地
  5. Android 获取SDCard上图片和视频的缩略图
  6. cf B. Number Busters
  7. macbook安装mysql
  8. C# 循环的应用 手机号抽奖 选班长的练习题
  9. c# 阶段总结
  10. 常用接口简析3---IList和List的解析
  11. 转 Caffe学习系列(5):其它常用层及参数
  12. [WEB]绕过安全狗与360PHP一句话的编写
  13. 微信小程序<swiper-item>标签中传入多个数组型数据的方法(小程序交流群:604788754)
  14. EOF多行写入文件防止变量替换
  15. Search中的剪枝-奇偶剪枝
  16. git的团队协作开发
  17. 2016.07.13-vector<vector<int>>应用2——Two Sum扩展
  18. springMVC传递一组对象的接受方式
  19. 泛型和 Any 类型
  20. [典型漏洞分享]上传导致的应用层DOS攻击

热门文章

  1. 分布式ID增强篇--优化时钟回拨问题
  2. zabbix4.0短信告警配置
  3. Nginx 教程 (1):基本概念
  4. LuaLuaMemorySnapshotDump-master
  5. PHP算法[转]
  6. 牛客小白月赛16 H小阳的贝壳 (线段树+差分数组)
  7. spring的统一进行异常处理
  8. .net core webapi添加swagger
  9. Go 数组(1)
  10. C++ 从txt文本中读取map