#go #go-gorm
# #Вперед #go-gorm
Вопрос:
Я хочу получить связанные данные из другой таблицы
У меня есть следующие структуры модели
type Community struct {
ID string `json:"id" gorm:"primaryKey"`
Name string `json:"name"`
Category CommunityCategory `json:"category" gorm:"foreignKey:ID"`
}
type CommunityCategory struct {
ID uint32 `json:"id" gorm:"primaryKey"`
Name string `json:"name"`
}
И мой код для получения данных выглядит примерно так
community := Community{ID: 1}
database.Debug().Joins("CommunityCategory").First(amp;community)
При этом я получаю следующую ошибку ERROR: invalid reference to FROM-clause entry for table "communities" (SQLSTATE 42P01)
И, глядя на журнал отладки GORM, запрос выглядит следующим образом
SELECT "communities"."id","communities"."name","communities"."introduction","communities"."address","communities"."postal_code","communities"."country","communities"."address1","communities"."address2","communities"."prefecture","communities"."city","communities"."lat","communities"."lng","communities"."phone","communities"."email","communities"."external_link_1","communities"."external_link_2","communities"."image_url","communities"."access","communities"."description","communities"."contact_name","communities"."contact_phone","communities"."contact_email","communities"."is_enabled","communities"."created_at","communities"."updated_at" FROM "communities" CommunityCategory WHERE "communities"."id" = '25b1eadf-1004-40b7-b9a2-325a83bcb938' ORDER BY "communities"."id" LIMIT 1
Я делаю это неправильно? Лол
Комментарии:
1. я думаю, что я на один шаг ближе к тому, чтобы заставить его работать сейчас. Я только что изменил аргумент на
Joins
"Category"
вместо"CommunityCategory"
. Но теперь выполняемый запрос выглядит такSELECT "communities"."id","Category"."id" AS "Category__id","Category"."name" AS "Category__name" FROM "communities" LEFT JOIN "community_categories" "Category" ON "communities"."id" = "Category"."id" WHERE "communities"."id" = '25b1eadf-1004-40b7-b9a2-325a83bcb938' ORDER BY "communities"."id" LIMIT 1
, но теперь ОБЪЕДИНЕНИЕ таблицы неверно. Это должно быть...ON communities.category_id = category.id
2. вы можете попробовать
database.Debug().Preload("Category").First(amp;community)
, но вам придется протестировать его, чтобы убедиться, что он будет правильно использовать внешний ключ и находить данные.
Ответ №1:
Исправил это, определив мою структуру следующим образом. Я добавил новое поле CategoryID
в Community
struct и изменил внешний ключ на это новое поле
type Community struct {
ID string `json:"id" gorm:"primaryKey"`
Name string `json:"name"`
CategoryID uint32
Category CommunityCategory `json:"category" gorm:"foreignKey:CategoryID"`
}
type CommunityCategory struct {
ID uint32 `json:"id" gorm:"primaryKey"`
Name string `json:"name"`
}
затем по запросу вы можете выполнить соединение следующим образом:
community := Community{ID: 1}
database.Model(amp;Community{}).Joins("Category").First(amp;community)