首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有外键关系的ASP.NET核心网络API & EF核心模型

带有外键关系的ASP.NET核心网络API & EF核心模型
EN

Stack Overflow用户
提问于 2019-02-08 16:03:16
回答 3查看 8.6K关注 0票数 2

我正在为教育目的开发一个基本的Web项目,而且我的EF模型关系也有问题。我有两个模特。MessageMessageBoard.

代码语言:javascript
复制
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控制器。迁移似乎正确地检测了这两个模型之间的关系:

代码语言:javascript
复制
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

代码语言:javascript
复制
{
 "Name":"Test Board",
 "Description":"A Message board for testing purposes."
}

返回

代码语言:javascript
复制
{
    "id": 4,
    "name": "Test Board",
    "description": "A Message board for testing purposes.",
    "messages": null
}

2)发送新消息

POST - https://localhost:44384/api/Messages

Body - Raw - JSON

代码语言:javascript
复制
{
    "Text":"Posting my first message!",
    "User":"Jesse",
    "PostedDate":"1/1/2019",

    "MessageBoardId":4
}

返回

代码语言:javascript
复制
{
    "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之外,我还删除了其他操作。

代码语言:javascript
复制
[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);
        }
}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-02-08 16:11:34

你需要负载相关数据

例如,对于您的MessageBoard GET - // GET: api/MessageBoards/5

更改如下:

代码语言:javascript
复制
var messageBoard = await _context.MessageBoards.FindAsync(id);

代码语言:javascript
复制
var messageBoard = await _context.MessageBoards
                        .Include(i=>i.Messages)
                        .FirstOrDefaultAsync(i => i.Id == id);
票数 4
EN

Stack Overflow用户

发布于 2019-02-08 16:14:56

我希望messageBoard不会为null,而是返回先前创建的messageBoard的JSON。如果我更改为GET方法,它也是空的。为什么是空的?

这是因为您正在返回新创建的消息,这里只存在MessageBoadId,而不是MessageBoad对象。因此,您必须使用Include从数据库中加载相关的MessageBoad,用于新创建的消息。

您的PostMessage方法应该如下:

代码语言:javascript
复制
// 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);
}
票数 2
EN

Stack Overflow用户

发布于 2019-02-08 16:10:49

您已经给出了应用程序输出和数据库的样子,但没有给出它如何保存/检索数据的中间位。在不知道中间发生了什么的情况下,我在黑暗中最好的尝试是,您既没有正确设置延迟加载,也没有使用Include来包含MessageBoard实体。

更多的信息这里关于他们是什么。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54596180

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档