DbSetの拡張機能とは? メソッド「FindTheLatest」を追加したい。これは私のコードです: これは私のコードです
public static List FindTheLatest(this DbSet<Review> reviews, int nums) { return reviews.OrderByDescending(r => r.Created).Take(nums).ToList(); }
しかし、うまくいきません。私は何をしなければなりませんか?
これは私の拡張クラスです:
public static class RestaurantReviewsExtenstion
{
public static IEnumerable<Review> FindTheLatest(this IQueryable<Review> reviews, int nums)
{
return reviews.OrderByDescending(r => r.Created).Take(nums).ToList();
}
public static Review FindById(this System.Data.Entity.DbSet<Review> reviews, int id)
{
return reviews.SingleOrDefault(s => s.ReviewId == id);
//return reviews.Find(item => item.Id == id);
}
public static Review FindTheBest(this List<Review> list)
{
return list.OrderByDescending(o => o.Rating).FirstOrDefault();
}
}
これは私の DBContex クラスです:
public class OdeToFoodDb: DbContext
{
public DbSet<Restaurant> Restaurants { get; set; }
public DbSet<Review> Reviews { get; set; }
protected override void OnModelCreating(System.Data.Entity.DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Restaurant>()
.HasMany(resturant => resturant.Reviews)
.WithRequired(review => review.Resturant);
base.OnModelCreating(modelBuilder);
}
}
ここでエラーが発生します:
OdeToFoodDb _db = new OdeToFoodDb();
public PartialViewResult LatestReview()
{
System.Threading.Thread.Sleep(1500);
//this is where i get error
var review = _db.Reviews.FindTheLatest(1);
//************************************
return PartialView("_Review", review);
}
貧弱な情報で申し訳ありません。