我正在为教育目的开发一个基本的Web项目,而且我的EF模型关系也有问题。我有两个模特。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脚手架生成了两个Web控制器。迁移似乎正确地检测了这两个模型之间的关系:
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的消息时,它们似乎没有正确地链接。在PostMan中,我执行以下操作:
1)发布一个新的MessageBoard
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不会为null,而是返回先前创建的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);
}
}发布于 2019-02-08 16:11:34
你需要负载相关数据
例如,对于您的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);发布于 2019-02-08 16:14:56
我希望messageBoard不会为null,而是返回先前创建的messageBoard的JSON。如果我更改为GET方法,它也是空的。为什么是空的?
这是因为您正在返回新创建的消息,这里只存在MessageBoadId,而不是MessageBoad对象。因此,您必须使用Include从数据库中加载相关的MessageBoad,用于新创建的消息。
您的PostMessage方法应该如下:
// POST: api/Messages
[HttpPost]
public async Task<ActionResult<Message>> PostMessage(Message message)
{
_context.Messages.Add(message);
await _context.SaveChangesAsync();
var message = await _context.Messages
.Include(i=>i.MessageBoard)
.FirstOrDefaultAsync(i => i.Id == message.Id);
return Json(message);
}发布于 2019-02-08 16:10:49
您已经给出了应用程序输出和数据库的样子,但没有给出它如何保存/检索数据的中间位。在不知道中间发生了什么的情况下,我在黑暗中最好的尝试是,您既没有正确设置延迟加载,也没有使用Include来包含MessageBoard实体。
更多的信息这里关于他们是什么。
https://stackoverflow.com/questions/54596180
复制相似问题