Как получить связанные данные с помощью 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(&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

Я что делаю неправильно? Ржу не могу


person junerey    schedule 24.11.2020    source источник
comment
Думаю, я на шаг ближе к тому, чтобы он заработал. Я только что изменил аргумент 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   -  person junerey    schedule 24.11.2020
comment
вы можете попробовать database.Debug().Preload("Category").First(&community), но вам нужно будет протестировать его, чтобы увидеть, правильно ли он будет использовать внешний ключ и найдет данные.   -  person Emin Laletovic    schedule 24.11.2020


Ответы (1)


Исправлено это, определив мою структуру следующим образом. Я добавил новое поле CategoryID в структуру Community и изменил внешний ключ на это новое поле

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(&Community{}).Joins("Category").First(&community)
person junerey    schedule 25.11.2020