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

Mysql子句查询陷阱

高老师8年前 (2017-06-24)SQL1698

例如我们需要查询商品表中每个分类中商品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子句查询陷阱” 的相关文章

mysql group分组排序

mysql group分组排序

下面的是商品数据表,id是主键,catename是分类,titile是标题,price是价格,现在要求计算每种分类下的商品平均价格.id     catename       &n...

Mysql exists型子查询

Mysql exists型子查询

需求查询出存在商品的商品分类.    先看看分类表:id(分类的id)    catename(分类名) 1         手机 2 &n...

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

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

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

mysql恢复数据库,mysql数据库log文件恢复数据库

mysql恢复数据库,mysql数据库log文件恢复数据库

由于在开发中不小心删除客户上传的商品数据,客户本身也不好说话,只好恢复数据库,记录下过程。原理是数据库开启bin-log功能,然后再通过备份的bin-log进行数据库恢复。先查找备份的数据库日志二进制文件。一般在mysql的data文件夹中,文件名大概为mysql-bin.00001,具体看文件的修...

 mysql count 性能优化,mysql count(*)优化

mysql count 性能优化,mysql count(*)优化

1.很多人认为count查询非常快,但是在加上筛选条件那就是未必的了!测试:user表中4000w数据(1).SELECT  count(*)   from user;   用时0.00s (2).SELECT...

mysql diff,mysqldiff 安装,mysqldiff 用法

mysql diff,mysqldiff 安装,mysqldiff 用法

项目和第三方系统对接,由于第三方开发人员属于兼职,数据库结构不一致的问题只能我来处理。此处文章用本地模拟演示。数据库资料:1号服务器:  账号root 密码root  IP:127.0.0.1  数据库名称:data1 2号服务器...