1

给定代码:

/// <summary>
/// Get a games high scores
/// </summary>
public static List<Score> GetGameHighScores(int gameID, HighScoreType type, int? skip = null, int? take  = null)
{
    var r = new List<Score>();

    using (var db = new ArcadeContext())
    {
        var q = new List<ArcadeScore>();

        if (skip != null && take != null)
        {
            switch (type)
            {
                case HighScoreType.ScoreRank:
                    q =
                        db.ArcadeScores.Where(c => c.GameID == gameID && c.ScoreRank > 0)
                            .OrderBy(c => c.ScoreRank)
                            .Skip(skip.Value)
                            .Take(take.Value)
                            .ToList();
                    break;
                case HighScoreType.UserRank:
                    q =
                        db.ArcadeScores.Where(c => c.GameID == gameID && c.UserRank > 0)
                            .OrderBy(c => c.UserRank)
                            .Skip(skip.Value)
                            .Take(take.Value)
                            .ToList();
                    break;
            }
        }
        else
        {
            switch (type)
            {
                case HighScoreType.ScoreRank:
                    q =
                        db.ArcadeScores.Where(c => c.GameID == gameID && c.ScoreRank > 0)
                            .OrderBy(c => c.ScoreRank)
                            .ToList();
                    break;
                case HighScoreType.UserRank:
                    q =
                        db.ArcadeScores.Where(c => c.GameID == gameID && c.UserRank > 0)
                            .OrderBy(c => c.UserRank)
                            .ToList();
                    break;
            }
        }
        r.AddRange(q.Select(arcadeScore => new Score(arcadeScore)));
    }
    return r;
} 

可选参数在哪里skiptake是可选参数(用于需要分页时),获取正确记录而不像上面那样重复自己的最佳方法是什么?

4

4 回答 4

9

无需在四个单独的查询之间切换,而是根据您的条件构建单个查询:

IQueryable<Score> query = db.ArcadeScores.Where(c => c.GameID == gameID);

switch(type)
{
    case HighScoreType.ScoreRank:
        query = query.Where(c => c.ScoreRank > 0).OrderBy(c => c.ScoreRank);
        break;
    case HighScoreType.UserRank:
        query = query.Where(c => c.UserRank > 0).OrderBy(c => c.UserRank);
        break;
}

if (skip.HasValue && take.HasValue)
   query = query.Skip(skip.Value).Take(take.Value);

return query.ToList();
于 2013-07-01T13:19:37.037 回答
1

鉴于在IEnumerable您调用之前不会执行,ToList您可以简单地将它们移到 switch 语句之外,然后调用ToList

于 2013-07-01T13:16:44.120 回答
1

只需使用 coalesce 运算符来提供默认值:

.Skip(skip ?? 0)
.Take(take ?? int.MaxValue)
于 2013-07-01T13:16:52.273 回答
0

可能,将其提取到一个方法中,以便您只在需要分页的时候调用 OrderBy 和 Skip。

db.ArcadeScores.Where(c => c.GameID == gameID && c.ScoreRank > 0)
                                .OrderBy(c => c.ScoreRank).

db.ArcadeScores.Where(c => c.GameID == gameID && c.UserRank > 0)
                            .OrderBy(c => c.UserRank)

进入

private IEnumerable<ArcadeScore> GetArcadeOverallScore(int gameId)
{
   return db.ArcadeScores.Where(c => c.GameID == gameID && c.ScoreRank > 0)
                                    .OrderBy(c => c.ScoreRank)
}

private IEnumerable<ArcadeScore> GetArcadeUserScore(int gameId)
{
   return db.ArcadeScores.Where(c => c.GameID == gameID && c.UserRank > 0)
                                .OrderBy(c => c.UserRank)
}
于 2013-07-01T13:21:53.267 回答