[英]How to add a foreign key into a table using one-to-one relationship in ASP.NET Core 6 Web API?
[英]ASP.NET Core Web API & EF Core Models with Foreign Key relationship
我正在開發一個用於教育目的的基本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腳手架生成了兩個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不會為null,而是返回先前創建的messageBoard的JSON。 如果更改為GET方法,則它也為null。 為什么它為空?
編輯:這是我的控制器。 我刪除了除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不會為null,而是返回先前創建的messageBoard的JSON。 如果更改為GET方法,則它也為null。 為什么它為空?
這是因為你正在返回新創建的消息,這里只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);
}
您需要加載相關數據
例如,對於您的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);
您已經給出了應用程序的輸出以及數據庫的外觀,但是沒有給出如何保存/檢索數據的中間內容。 在不知道中間發生了什么的情況下,我最好的解決方法是既沒有正確設置延遲加載,也沒有使用Include
來包含MessageBoard
實體。
有關它們的詳細信息,請點擊此處 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.