- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
如何通过 Linq to Sql 获得评分最高的 5 个产品?
我的产品类是
public class Product
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int ProductID { get; set; }
public string Name { get; set; }
public decimal Price { get; set; }
}
我的 ProductReviews 类是
public class ProductReview
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int ProductReviewID { get; set; }
public int ProductID { get; set; }
public int Rating { get; set; }
public virtual Product Product { get; set; }
}
最佳答案
假设您想从每个产品的所有评论中获取评分的简单平均值,下面的代码(包括示例数据)应该可以解决问题(我已经针对对象对 LINQ 进行了测试,但 应该也可以与 LINQ to SQL 一起工作):
var products = new List<Product>
{
new Product { ProductID = 1, Name= "Product 1", Price = 1.00m },
new Product { ProductID = 2, Name= "Product 2", Price = 1.00m },
new Product { ProductID = 3, Name= "Product 3", Price = 1.00m },
new Product { ProductID = 4, Name= "Product 4", Price = 1.00m },
new Product { ProductID = 5, Name= "Product 5", Price = 1.00m },
new Product { ProductID = 6, Name= "Product 6", Price = 1.00m }
};
var productReviews = new List<ProductReview>
{
new ProductReview { ProductReviewID = 1, ProductID = 1, Rating = 5 },
new ProductReview { ProductReviewID = 2, ProductID = 1, Rating = 3 },
new ProductReview { ProductReviewID = 3, ProductID = 2, Rating = 1 },
new ProductReview { ProductReviewID = 4, ProductID = 3, Rating = 4 },
new ProductReview { ProductReviewID = 5, ProductID = 4, Rating = 2 },
new ProductReview { ProductReviewID = 6, ProductID = 5, Rating = 5 },
new ProductReview { ProductReviewID = 7, ProductID = 6, Rating = 4 },
new ProductReview { ProductReviewID = 8, ProductID = 6, Rating = 3 }
};
var averageProductRatings = from review in productReviews
group review by review.ProductID into product
select new
{
ProductId = product.Key,
AverageRating = product.Average(p => p.Rating)
};
var top5 = averageProductRatings.OrderByDescending(average => average.AverageRating).Take(5);
第一个语句是获取评论数据,按 ProductID
分组并计算每个产品的 Rating
的平均值。
第二个语句然后是对每个产品取平均值,并为您提供平均评分最高的 5 个产品。
如果您想做一些不同的事情(比如给最近的评论更高的权重),您可以将“产品”传递给计算该产品评级的自定义函数,例如:
var averageProductRatings = from review in productReviews
group review by review.ProductID into product
select new
{
ProductId = product.Key,
AverageRating = GetProductRatingFromReviews(product)
};
private double GetProductRatingFromReviews(IGrouping<int, ProductReview> productReviews)
{
// Work out the aggregate rating to give the product here and return it
foreach (var item in productReviews)
{
}
return -1;
}
关于c# - Linq 到 SQL : Get Top 5 Rated products,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33043874/
SELECT username, (SUM(rating)/count(*)) as TheAverage, count(*) as TheCount FROM ratings WHERE month
通常我的计数器指标查询如下所示: rate(metric_total[5m]) rate(metric_total[$__interval]) 但是在查看使用 Prometheus 和 Grafana
@Override public void onPositiveButtonClicked(int value, @NotNull String comments) { Rating rati
我尝试创建一个自定义评级栏。我不使用 style 因为我只用过一次。因此,我在 drawable 文件夹中创建了一个 layer-list(它的名称是 custom_rating_bar.xml):
我尝试通过 Django 评级应用程序评级来排序一组模型对象。我在我看来构建了一个 order_by 函数,该函数工作正常,但当我进入评级字段时,我收到此错误:“评级值必须是评级实例,而不是'100”
更新:我输错了 2 个变量...太尴尬了。感谢大家的努力! 抱歉,我发现我为 2 个不同的环境输入了错误的值,第一个我设置了 sort = 0 和 rating=1 但后来在 irb 中我设置了 so
当我使用 Keras 定义模型时,大多数时候都会收到此警告。它似乎以某种方式来自 tensorflow: WARNING:tensorflow:From C:\Users\lenik\AppData\
我有一个二元分类问题,类别背景 (bg) = 0,信号 (sig) = 1,我正在为此训练神经网络。出于监控目的,我尝试在 Keras 中使用 TensorFlow 后端实现自定义指标,该指标执行以下
所以我们有如下电影评分关系数据库: mysql> select * from ratings; +-----+-----+------+ | uid | mid | rid | +-----+-
我正在使用 AVAudioRecorder。我以 44100 采样率以 caf 格式 录制音频。就记录成功了。录制后,我想转换已录制的 caf 采样率为 11025 和 22050 的音频文件。是否可
因此,我们的 ASP.NET4 Web 应用程序中有一个利率计算器类,它使用 Microsoft.VisualBasic.Financial.Rate 来计算名义利率(基于输入参数)。 我们注意到,对
我想用生成器构建一个数独游戏。我已经想出了在没有难度级别的情况下如何做的一切:简单、中等、困难。我的问题是根据难度级别我应该隐藏多少个数字?任何想法。 最佳答案 我很确定数独谜题的难度等级不是根据缺失
如何防止客户对产品进行多次评分?最好使用存储 IP 地址的 cookie,还是最好将用户评级存储在数据库中?我正在使用 MySQL 和 ColdFusion。 干杯! 最佳答案 如果您有用户帐户,请将
项目简介 rate-limit 是一个为 java 设计的渐进式限流工具. 目的是为了深入学习和使用限流,后续将会持续迭代. 特性 渐进式实现 。 支持独立于 spri
我们使用 spring-cloud-gateway 使用 RedisRateLimiter 进行速率限制。如果我们有一个按键来按每条路线进行速率限制,一切都可以立即使用。但是,我们有一个用例,其中针对
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 去年关闭。 Improve th
Lyft文档(https://developer.lyft.com/docs/rate-limits)中有一条信息,即“费率限制是全局的,并基于每个客户端ID强制执行。”。真的是这样吗? Lyft会根
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
引自普罗米修斯 Count and sum of observations文档: To calculate the average request duration during the last 5
引自普罗米修斯 Count and sum of observations文档: To calculate the average request duration during the last 5
我是一名优秀的程序员,十分优秀!