![](/img/trans.png)
[英]How get data from asp.net web api in asp.net mvc controller in the same project
[英]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
,則可以這樣做。
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.