c# - 具有外键关系的 ASP.NET Core Web API 和 EF Core 模型
问题描述
我正在为教育目的开发一个基本的 Web API 项目,但我的 EF 模型关系有问题。我有2个模型。Message
和MessageBoard
。
public class Message
{
public long Id { get; set; }
public string Text { get; set; }
public string User { get; set; }
public DateTime PostedDate { get; set; }
public long MessageBoardId { get; set; }
[ForeignKey("MessageBoardId")]
public MessageBoard MessageBoard { get; set; }
}
public class MessageBoard
{
public long Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public ICollection<Message> Messages { get; set; }
}
我已经设置了我的 DBContext 并创建了一个迁移来配置数据库。我使用 EF Scaffolding 生成了两个 Web API 控制器。迁移似乎正确检测了两个模型之间的关系:
modelBuilder.Entity("Asp.net_Core_Web_Api.Models.Message", b =>
{
b.HasOne("Asp.net_Core_Web_Api.Models.MessageBoard", "MessageBoard")
.WithMany("Messages")
.HasForeignKey("MessageBoardId")
.OnDelete(DeleteBehavior.Cascade);
});
但是,当我创建一个 MessageBoard 然后使用 MessageBoard 的 ID 创建一个 Message 时,它们似乎没有正确链接。在 PostMan 中,我正在执行以下操作:
1) 发布一个新的留言板
POST - https://localhost:44384/api/MessageBoards/
Body - Raw - Json
{
"Name":"Test Board",
"Description":"A Message board for testing purposes."
}
退货
{
"id": 4,
"name": "Test Board",
"description": "A Message board for testing purposes.",
"messages": null
}
2) 发布新消息
POST - https://localhost:44384/api/Messages
Body - Raw - JSON
{
"Text":"Posting my first message!",
"User":"Jesse",
"PostedDate":"1/1/2019",
"MessageBoardId":4
}
退货
{
"id": 2,
"text": "Posting my first message!",
"user": "Jesse",
"postedDate": "2019-01-01T00:00:00",
"messageBoardId": 4,
"messageBoard": null
}
我希望 messageBoard 不会为空,而是返回先前创建的 messageBoard 的 JSON。如果我更改为 GET 方法,它也为空。为什么它是空的?
编辑:这是我的控制器。我删除了除 GET 和 POST 之外的操作。
[Route("api/[controller]")]
[ApiController]
public class MessageBoardsController : ControllerBase
{
private readonly MessageBoardContext _context;
public MessageBoardsController(MessageBoardContext context)
{
_context = context;
}
// GET: api/MessageBoards/5
[HttpGet("{id}")]
public async Task<ActionResult<MessageBoard>> GetMessageBoard(long id)
{
var messageBoard = await _context.MessageBoards.FindAsync(id);
if (messageBoard == null)
{
return NotFound();
}
return messageBoard;
}
// POST: api/MessageBoards
[HttpPost]
public async Task<ActionResult<MessageBoard>> PostMessageBoard(MessageBoard messageBoard)
{
_context.MessageBoards.Add(messageBoard);
await _context.SaveChangesAsync();
return CreatedAtAction("GetMessageBoard", new { id = messageBoard.Id }, messageBoard);
}
}
[Route("api/[controller]")]
[ApiController]
public class MessagesController : ControllerBase
{
private readonly MessageBoardContext _context;
public MessagesController(MessageBoardContext context)
{
_context = context;
}
// GET: api/Messages/5
[HttpGet("{id}")]
public async Task<ActionResult<Message>> GetMessage(long id)
{
var message = await _context.Messages.FindAsync(id);
if (message == null)
{
return NotFound();
}
return message;
}
// POST: api/Messages
[HttpPost]
public async Task<ActionResult<Message>> PostMessage(Message message)
{
_context.Messages.Add(message);
await _context.SaveChangesAsync();
return CreatedAtAction("GetMessage", new { id = message.Id }, message);
}
}
解决方案
您需要加载相关数据
例如,对于您的MessageBoard
GET -// GET: api/MessageBoards/5
更改自:
var messageBoard = await _context.MessageBoards.FindAsync(id);
至
var messageBoard = await _context.MessageBoards
.Include(i=>i.Messages)
.FirstOrDefaultAsync(i => i.Id == id);
推荐阅读
- java - 如何告诉用户他/她输入的天数已经被保留?
- ruby - 为什么我的 ruby watir 黄瓜框架的步骤文件中出现此错误
- ruby - 如何配置 iex-ruby-client gem 以使用常规 ruby 程序(不是 rails)?
- rest - Rest API 替代轮询异步长时间运行的任务
- python-3.x - 如何检查输入是浮点数还是整数?
- pointers - t=&T{} 和 t=new(T) 的核心区别是什么
- c# - 数据绑定看不到 viewmodel 属性
- c# - Asp.net MVC 多对多连接表
- r - geom_smooth 公式中的小写到大写影响线性回归绘图
- python - 编写一个将信息存储在字典中的函数。Python3 错误:“语法错误:‘返回’外部函数”