pages/ru_RU/docs/has_many.md
Связь has many (имеет много) устанавливает связь с другой моделью, в отличие от has one (имеет одну), владелец может не иметь или иметь много экземпляров моделей.
Например, если ваше приложение включает пользователей и кредитные карты, и каждый пользователь может иметь много кредитных карт.
// User имеет много CreditCards, UserID это внешний ключ
type User struct {
gorm.Model
CreditCards []CreditCard
}
type CreditCard struct {
gorm.Model
Number string
UserID uint
}
// Retrieve user list with eager loading credit cards
func GetAll(db *gorm.DB) ([]User, error) {
var users []User
err := db.Model(&User{}).Preload("CreditCards").Find(&users).Error
return users, err
}
Чтобы определить связь has many (имеет много), должен существовать внешний ключ. Имя внешнего ключа по умолчанию - это имя типа владельца плюс имя поля первичного ключа
Например, для определения модели, принадлежащей User, внешний ключ должен быть UserID.
Чтобы использовать другое поле в качестве внешнего ключа, вы можете настроить его с помощью тега foreignKey, например:
type User struct {
gorm.Model
CreditCards []CreditCard `gorm:"foreignKey:UserRefer"`
}
type CreditCard struct {
gorm.Model
Number string
UserRefer uint
}
GORM обычно использует первичный ключ владельца в качестве значения внешнего ключа, для приведенного выше примера это ID модели User,
При назначении кредитных карт пользователю, GORM сохранит ID пользователя в поле UserID.
Вы можете изменить поле связи с помощью тега references, например:
type User struct {
gorm.Model
MemberNumber string
CreditCards []CreditCard `gorm:"foreignKey:UserNumber;references:MemberNumber"`
}
type CreditCard struct {
gorm.Model
Number string
UserNumber string
}
Пожалуйста, смотрите режим связей для работы с has many (имеет много) связями
GORM позволяет использовать нетерпеливую загрузку для связей has many (имеет много) с помощью Preload, смотрите Предзагрузка (Нетерпеливая загрузка) для подробностей
type User struct {
gorm.Model
Name string
ManagerID *uint
Team []User `gorm:"foreignkey:ManagerID"`
}
Вы можете настроить OnUpdate, OnDelete ограничения с помощью тега constraint, они будут созданы при миграции с помощью GORM, например:
type User struct {
gorm.Model
CreditCards []CreditCard `gorm:"constraint:OnUpdate:CASCADE,OnDelete:SET NULL;"`
}
type CreditCard struct {
gorm.Model
Number string
UserID uint
}
Вы также можете удалить выбранные ассоциации has many с помощью Select при удалении, ознакомьтесь с Delete with Select для подробностей