当前位置:首页 > SQL > 正文内容

Mysql子句查询陷阱

高老师9年前 (2017-06-24)SQL1923

例如我们需要查询商品表中每个分类中商品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

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/295.html

分享给朋友:

“Mysql子句查询陷阱” 的相关文章

Left join,​Right join,​Inner join的区别实例讲解

Left join,​Right join,​Inner join的区别实例讲解

Left join:即左连接,是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。Right join:即右连接,是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表...

主键primary key是否必须和auto_increment 一起出现

主键primary key是否必须和auto_increment 一起出现

    一般情况下,绝大部分,我们的主键是数字,1 2 3 4...所以我们才让它递增.这并不意味着,他们两个必须要绑定在一起使用.例如我还想将用户表的email字段设置为主键,但是并没有必要为其设置自增。    因此可...

mysql常用函数

mysql常用函数

1.floor(x)返回小于x的整数,向下取整,用法,商品的价格是浮点型的,需要向下取整 eg:select id,title,floor(price)  from  shopgoods2.rand()返回0-1之间的随机数 select rand() select rand()...

三大范式通俗解释,数据库三大范式通俗解释

三大范式通俗解释,数据库三大范式通俗解释

概述: 目前我们的表设计,最高级别的范式是6NF,对于PHP程序员而言,我们的表满足3NF即可(范式即规范)【一】1NF    (1).所谓1NF,就是指标的属性具有原子性,即表的列不能再分割,不能分割意思是字段本身的含义(例如address字段不能再分割)...

mysql 取不重复数据,mysql 取消重复数据,mysql 重复记录取最新

mysql 取不重复数据,mysql 取消重复数据,mysql 重复记录取最新

已有表名log来记录用户日志,id是主键,uid是用户id,rmk是备注,addtime是时间戳,需要取出不重复的用户日志记录默认的结果集:id     uid      rmk ...

mysql 自定义排序,mysql 自定义字段排序,mysql 强制自定义排序

mysql 自定义排序,mysql 自定义字段排序,mysql 强制自定义排序

通常我们使用自定义排序的语法是:ORDER BY FIELD(`字段名称`, 值1, 值2, 值3),但是如果我想强制值1到值3永远在前面,这个语法是满足不了的.(1).基本的会员数据表:id      name  &n...