首页 > 解决方案 > Phoenix 不呈现关联

问题描述

我有一个简单的待办事项/作者/评论

Todo has_many comments
Comment belongs_to Todo
Todo belongs_to Author
Author has_many todos
Author has_many comments
Comment belongs_to Author

如果我像这样渲染 todo_view.ex:

  def render("todo.json", %{todo: todo}) do
    %{id: todo.id,
      title: todo.title,
      description: todo.description,
      date: todo.date,
      author: author_json(todo.author)}
  end
  defp author_json(author) do
    %{name: author.name}
  end

当我访问时一切正常/api/todos/api/comments 但是如果我想为待办事项添加评论列表:

  def render("todo.json", %{todo: todo}) do
    %{id: todo.id,
      title: todo.title,
      description: todo.description,
      date: todo.date,
      author: author_json(todo.author),
      comments: render_many(todo.comments, CommentView, "comment.json")}
  end

我在 comment_view.ex 中得到一个 KeyError

键:名称未在:#Ecto.Association.NotLoaded

  def render("comment.json", %{comment: comment}) do
    %{id: comment.id,
      content: comment.content,
      author: author_json(comment.author)}
  end
  defp author_json(author) do
    %{name: author.name}
  end

不知何故,Elixir 在查询待办事项时看不到评论/作者关联,但在查询评论时确实看到了。

我做了预加载评论:

comments = Repo.all(Comment) |> Repo.preload(:author)

知道这里发生了什么吗?

标签: elixirphoenix-framework

解决方案


从数据库中author获取数据时是否预加载?todos像这样的东西:

todos = Todo |> Repo.all() |> Repo.preload([comments: [:author]])

这会加载所有ToDosComments他们的Author关联。


推荐阅读