Rails вызывает разные поля в одной таблице

Я хочу вызывать разные поля в одной таблице,

Назначено != Открыто кем

Я не могу вызвать пользователю, которому назначена тема

таблица пользователей mysql

таблица проблем mysql

скриншот show.html.erb

<p>
  <strong>Assignedby:</strong>
  <%= @issue.user.try(:fullname) %>

</p>

<p>
  <strong>Openedby:</strong>
 <%= @issue.user.try(:fullname) %>

</p>

class Issue < ApplicationRecord

  belongs_to :project, foreign_key: :project_id, optional: true

  belongs_to :user, foreign_key: :assignedby_id, optional: true

  belongs_to :user, foreign_key: :openedby_id, optional: true

  belongs_to :user, foreign_key: :closedby_id, optional: true

end

вы не можете определить несколько отношений с одним и тем же именем (в вашем случае user). Вы должны называть их как belongs_to :user_assigner, foreign_key: :assignedby_id, optional: true, class_name: 'User', belongs_to :user_opener, [...] и т. д. и т. д.

MrYoshiji 08.03.2019 20:17

@MrYoshiji, ты чертовски быстр :)

Muhammad Faisal Iqbal 08.03.2019 20:18

@MrYoshiji спасибо :)

Ozgur SARIOGLAN 08.03.2019 20:21
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
3
49
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Нельзя давать всем этим belongs_to ассоциациям одно и то же имя, они должны быть разными, например:

class Issue < ApplicationRecord
  with_option optional: true do
    belongs_to :project
    belongs_to :assigner, class_name: 'User', foreign_key: :assignedby_id
    belongs_to :creator,  class_name: 'User', foreign_key: :openedby_id
    belongs_to :closer,   class_name: 'User', foreign_key: :closedby_id
  end
end
assigned_user противоречит внешнему ключу, кажется, что здесь отношение указывает на пользователя, который его назначил, а не на того, кто ему назначен
MrYoshiji 08.03.2019 20:28

Другие вопросы по теме