Mysql子句查询陷阱

例如我们需要查询商品表中每个分类中商品id最大的记录,并且显示商品价格

以下是表结构:

id     catename         title     price 


1	手机		小米5		1500
2	手机		小米6		2500
3	手机		苹果6		2450
4	电脑		三星c201		5000
5	电脑		戴尔n4050	2000
6	充电宝	        小米充电宝	89
7	充电宝	        罗马仕		110
8	充电宝	        熊大大X能源	250

执行SQL:

select      max(id) ,catename,price   from    shop_goods    group by  catename

 我们会发现执行的结果如下

id      分类    价格
8	充电宝	89
3	手机	1500
5	电脑	5000

价格错误,其他都是正确的。

正确的SQL执行:

SELECT   id,catename,price  from   shop_goods    where  id  in(select      max(id)    from    shop_goods    group by  catename      )

正确的SQL执行结果:

id      分类     价格
3	手机	2450
5	电脑	2000
8	充电宝	250
访客
邮箱
网址

通用的占位符缩略图

人工智能机器人,扫码免费帮你完成工作


  • 自动写文案
  • 自动写小说
  • 马上扫码让Ai帮你完成工作
通用的占位符缩略图

人工智能机器人,扫码免费帮你完成工作

  • 自动写论文
  • 自动写软件
  • 我不是人,但是我比人更聪明,我是强大的Ai
Top