[英]Including only Id of related entity in 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在這些事情上對我來說似乎更直觀,但對於他自己......這是你的選擇。
.Include(m => m.Pictures.Select(p => p.Id))
將不起作用你必須做
.Include(m => m.Pictures)
這將為您提供一系列全畫面模型(所有屬性Id,MealId,..),在您的客戶端,您可以選擇Id來使用..
可能有一個更好的答案,但這是我修復它的方式。 包括整個Picture
類不是一個選項,因為二進制數據也將被包含在內並且我不想在不使用它的情況下向服務器查詢數據,因為這是對數據庫的昂貴調用。
所以我所做的是將二進制數據放在另一個名為PictureFile
類中(需要考慮一個更好的名稱,但只是File
顯然不是一個選項)。 PictureFile
類只引用相應的圖片和帶有圖片數據的字節數組。 這樣您就可以在不獲取實際文件的情況下將Pictures
包含在Meal
。 客戶端可以稍后決定它需要哪些圖片並通過PictureId
請求它們。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.