将有序表分组总是返回第一行吗? MySQL数据库
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了将有序表分组总是返回第一行吗? MySQL数据库,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1715字,纯文字阅读大概需要3分钟。
内容图文
我正在写一个查询,在其中将行的选择分组以找到其中一列的MIN值.
我还想返回与返回的MIN行关联的其他列值.
例如
ID QTY PRODUCT TYPE
--------------------
1 2 Orange Fruit
2 4 Banana Fruit
3 3 Apple Fruit
如果我通过“类型”列将此表分组,然后选择“最小数量”,它将不会返回对应于“最小”行的对应产品,在上述情况下为“苹果”.
在分组之前添加ORDER BY子句似乎可以解决此问题.但是,在继续将此查询包含在我的应用程序中之前,我只想知道此方法是否将始终返回正确的值.这是正确的方法吗?我已经看到了一些使用子查询的示例,但是我也读到这种效率低下.
提前致谢.
解决方法:
Adding an ORDER BY clause before grouping seems to solve the problem. However, before I go ahead and include this query in my application I’d just like to know whether this method will always return the correct value. Is this the correct approach? I’ve seen some examples where subqueries are used, however I have also read that this inefficient.
不,这不是正确的方法.
我相信您正在谈论这样的查询:
SELECT product.*, MIN(qty)
FROM product
GROUP BY
type
ORDER BY
qty
您在这里正在使用MySQL的扩展,该扩展允许您在GROUP BY查询中选择未聚合/未分组的列.
这主要用于在PRIMARY KEY上同时包含JOIN和GROUP BY的查询中,如下所示:
SELECT order.id, order.customer, SUM(price)
FROM order
JOIN orderline
ON orderline.order_id = order.id
GROUP BY
order.id
在这里,order.customer既没有分组也没有聚合,但是由于您是在order.id上分组,因此可以保证每个组中的值都相同.
在您的情况下,组中所有qty值具有不同的值.
无法保证引擎将从组中的哪个记录中获取值.
你应该做这个:
SELECT p.*
FROM (
SELECT DISTINCT type
FROM product p
) pd
JOIN p
ON p.id =
(
SELECT pi.id
FROM product pi
WHERE pi.type = pd.type
ORDER BY
type, qty, id
LIMIT 1
)
如果您在产品(类型,数量,编号)上创建索引,则此查询将快速运行.
内容总结
以上是互联网集市为您收集整理的将有序表分组总是返回第一行吗? MySQL数据库全部内容,希望文章能够帮你解决将有序表分组总是返回第一行吗? MySQL数据库所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。