簡體   English   中英

如何從 ASP.Net Core Web API Controller 中的數據庫返回關系數據

[英]How to return a relational data from DB in ASP.Net Core Web API Controller

我有3個關系表

1 個帖子、2 個評論、3 個圖像

“評論”和“圖像”表具有“帖子”外鍵。 我想使用 GET 方法在 ASP.Net Core Web API 中一起返回有關帖子的完整信息。 我知道如何創建 controller 之類的東西。 我的問題是關於檢索和返回數據。

如果您使用的是EFCore ,則可以這樣做。

  • 創建一個 ApiController
  • Constructor注入你的DbContext
  • DB讀取數據
  • 返回數據
[Route("api/[controller]")]
[ApiController]
public class PostController : BaseController
{
    private readonly ApplicationDbContext _dbContext;//Your DbContext
    public PostController(ApplicationDbContext dbContext)
    {
        _dbContext = dbContext;
    }
    [HttpGet]
    public IActionResult Get()
    {
        var data = _dbContext.Post.Include(a=> a.Comments).Include(a=> a.Images).ToList();
        return Ok(data);
    }

}

.Net Core中, Lazy loading是禁用的,當您 select 時,默認情況下不會加載來自數據庫的表。

如果要獲取所有具有關系的數據,則必須使用Include來加載這樣的關系

dbContext.Post.Include(a=> a.Comments).Include(a=> a.Images).ToList();

你的數據庫表應該是這樣的

public class Post
{
    public ICollection<Images> Images { get; set; }
    public ICollection<Comments> Comments { get; set; }
}
public class Comments
{
    public Post Post { get; set; }
}
public class Images
{
    public Post Post { get; set; }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM