在實體框架核心中僅包含相關實體的Id

c# entity-framework-core

我目前正在開發一個帶有ASP.NET核心和實體框架核心的API,其中npgsql作為數據庫提供者。我有兩個實體,他們有一對多的關係。問題是我只想在“父控制器”返回的JSON結果中包含子實體的Id。

這些是我的實體:

public class Meal {
    public int Id { get; set; }

    public string Title { get; set; }
    public string Description { get; set; }

    public string UserId { get; set; }
    public User User { get; set; }

    public List<Picture> Pictures { get; set; }

    public Meal () {
        this.Pictures = new List<Pictures>();
    }
}

public class Picture {
    public int Id { get; set; }

    public int MealId { get; set; }
    public Meal Meal { get; set; }

    public byte[] full { get; set; }
    public byte[] small { get; set; }
}

但我不確定如何實現這一目標。昨天我遇到了另一個提出類似問題的SO問題:

public IActionResult Meals () {
    var meal = this.context.Meals
        .Include(m => m.Pictures.Select(p => p.Id))
        .First();

    return new JsonResult(meal);
}

但是,這會拋出InvalidOperationException。我的DbContext是非常基本的,沒有onModelConfiguring,因為據我所知這個代碼遵循約定,它只有兩個相應類型的DbSet。外鍵在數據庫中也是正確的,並且調用類似於:

var pictures = dbContext.Pictures.Where(p => p.MealId == mealId).ToList();

按預期工作。我只包含了我認為相關的代碼。如果需要更多,我會包含它,但我認為這完全是我對查詢的有限理解。

感謝您的時間!

一般承認的答案

您不需要更改數據庫結構,一個選項是這樣的:

        var db = this.context;
        var result = (from meal in db.Meals
                      where meal.<whatever> == "123"
                      select new
                      {
                         Id = meal.Id,
                         Title = meal.Title,
                         Description = meal.Description,
                         //other required meal properties here.
                         PictureIds = meal.Pictures.Select(x => x.Id)
                      }).ToList();

你也可以通過使用“選擇”方法通過lambda做同樣的事情,Linq在這些事情上對我來說似乎更直觀,但對於他自己......這是你的選擇。


熱門答案

可能有更好的答案,但這就是我修復它的方法。包括整個Picture類不是一個選項,因為二進制數據也將被包含在內並且我不想在不使用它的情況下向服務器查詢數據,因為這是對數據庫的昂貴調用。

所以我所做的是將二進制數據放在另一個名為PictureFile類中(需要考慮一個更好的名稱,但只是File顯然不是一個選項)。 PictureFile類只引用相應的圖片和帶有圖片數據的字節數組。這樣您就可以將Pictures包含在Meal而無需獲取實際文件。客戶端可以在以後決定它需要哪些圖片並通過PictureId請求它們。



Related

許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因
許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因