获取每个类别的前 10 名产品
我有一个类似这样的查询
SELECT
t.category,
tc.product,
tc.sub-product,
count(*) as sales
FROM tg t, ttc tc
WHERE t.value = tc.value
GROUP BY t.category, tc.product, tc.sub-product;
现在在我的查询中我想获得每个类别的前 10 个产品(按销售额排名最高),对于每个类别我需要前 5 个子类别(按销售额排名最高)
您可以假设问题陈述为像这样:
获取每个类别的销售额排名前 10 的产品,以及每个产品获取销售额排名前 5 的子产品。
- 这里的类别可以是书籍
- 产品可以是 Harry Porter 图书
- 子产品可以是 HarryPorter 系列 5
示例输入数据格式
category |product |subproduct |Sales [count (*)]
abc test1 test11 120
abc test1 test11 100
abc test1 test11 10
abc test1 test11 10
abc test1 test11 10
abc test1 test11 10
abc test1 test12 10
abc test1 test13 8
abc test1 test14 6
abc test1 test15 5
abc test2 test21 80
abc test2 test22 60
abc test3 test31 50
abc test3 test32 40
abc test4 test41 30
abc test4 test42 20
abc test5 test51 10
abc test5 test52 5
abc test6 test61 5
|
|
|
bcd test2 test22 10
xyz test3 test31 5
xyz test3 test32 3
xyz test4 test41 2
输出将是“
top 5 rf for (abc) -> abc,test1(289) abc,test2 (140), abc test3 (90), abc test4(50) , abc test5 (15)
top 5 rfm for (abc,test1) -> test11(260),test12(10),test13(8),test14(6),test15(5) and so on
我的查询失败,因为结果真的很大。我正在阅读有关 Oracle 分析函数(如排名)的内容。有人可以帮我修改吗?” 也可以工作。
使用分析函数的任何其他方法 .com/node/55。但是无法获得正确的 sql 查询。
任何帮助将不胜感激。我在这个问题上被困了 2 天:(
I have a query which is something like this
SELECT
t.category,
tc.product,
tc.sub-product,
count(*) as sales
FROM tg t, ttc tc
WHERE t.value = tc.value
GROUP BY t.category, tc.product, tc.sub-product;
Now in my query I want to get top 10 products for every category (top by sales ) and for every category I need top 5 sub category (top by sales)
You can assume the problem statement as something like this :
Get top 10 products for each category by sales and for each product get top 5 sub-products by sales .
- Here category can be Books
- Product can be Harry Porter book
- sub productcan be HarryPorter series 5
Sample input data format
category |product |subproduct |Sales [count (*)]
abc test1 test11 120
abc test1 test11 100
abc test1 test11 10
abc test1 test11 10
abc test1 test11 10
abc test1 test11 10
abc test1 test12 10
abc test1 test13 8
abc test1 test14 6
abc test1 test15 5
abc test2 test21 80
abc test2 test22 60
abc test3 test31 50
abc test3 test32 40
abc test4 test41 30
abc test4 test42 20
abc test5 test51 10
abc test5 test52 5
abc test6 test61 5
|
|
|
bcd test2 test22 10
xyz test3 test31 5
xyz test3 test32 3
xyz test4 test41 2
Output would be "
top 5 rf for (abc) -> abc,test1(289) abc,test2 (140), abc test3 (90), abc test4(50) , abc test5 (15)
top 5 rfm for (abc,test1) -> test11(260),test12(10),test13(8),test14(6),test15(5) and so on
My query is failing because results are really huge . I am reading about oracle analytic functions like rank. Can someone help me modifying this query using analytical functions. Any other approach can also work.
I am referring to this http://www.orafaq.com/node/55. But unable to get a right sql query for this.
Any help would be appreciated..I am like stuck for 2 days on this :(
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
可能有一些原因不使用分析函数,而是单独使用分析函数:
我使用 rownum 而不是rank,这样你就不会得到平局,或者换句话说,平局将是随机决定的。如果数据不够密集(前 10 个产品中的任何一个产品中的子产品少于 5 个 - 它可能会显示其他产品的子产品),这也不起作用。但如果数据密集(大型数据库),查询应该可以正常工作。
The below makes two passes of the data, but returns correct results in each case. Again, this is a rank-without-ties query.
列:
There are probably reasons not to use analytical functions, but using analytical functions alone:
I used rownum instead of rank so you don't ever get ties, or in other words, ties will be randomly decided. This also doesn't work if the data is not dense enough (less than 5 subproducts in any of the top 10 products - it may show subproducts from some other products instead). But if the data is dense (large established database), the query should work fine.
The below makes two passes of the data, but returns correct results in each case. Again, this is a rank-without-ties query.
columns:
这是猜测,但您可能可以从以下内容开始:
一些测试数据:
实际查询:
在该查询中,
category_sales
列返回该类别的销售额总和它被返回到谁的记录中。这意味着,同一类别的每条记录都具有相同的category_sales
。需要此列来首先对结果集进行排序,其中最好的(销售)类别(order by ...category_sales desc
)。同样,
product_sales
是类别-产品组合的销售额总和。此列用于查找每个类别中最好的n(此处:10) 个产品(其中 top_product <= 10
)。top_product
列是使用dense_rank() over...
分析函数“创建”的。对于类别中最好的产品,它是 1,对于第二好的产品,它是 2,依此类推(因此where top_product <= 10
。top_suproduct
列的计算公式为类似的方式如top_product
(即使用dense_rank
)。It's guesswork, but you could probably start from something like this:
Some test data:
The actual query:
In that query, the column
category_sales
returns the sum of sales of the category in whose record it is returned. That means, every record of the same category has the samecategory_sales
. This column is needed to order the result set with the best (sales) categories first (order by ... category_sales desc
).Similarly,
product_sales
is the sum of sales for a category-product combination. This column is used to find the best n (here:10) products in each category (where top_product <= 10
).The column
top_product
is "created" with thedense_rank() over...
analytical function. For the best product in a category,it's 1, for the second best it's 2 and so on (hence thewhere top_product <= 10
.The column
top_suproduct
is calculated in a similar fashion liketop_product
(that is withdense_rank
).