Back to Gorm Io

Has Many (имеет много)

pages/ru_RU/docs/has_many.md

latest4.1 KB
Original Source

Has Many (имеет много)

Связь has many (имеет много) устанавливает связь с другой моделью, в отличие от has one (имеет одну), владелец может не иметь или иметь много экземпляров моделей.

Например, если ваше приложение включает пользователей и кредитные карты, и каждый пользователь может иметь много кредитных карт.

Declare

go
// User имеет много CreditCards, UserID это внешний ключ
type User struct {
  gorm.Model
  CreditCards []CreditCard
}

type CreditCard struct {
  gorm.Model
  Number string
  UserID uint
}

Retrieve

go
// 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, например:

go
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, например:

go
type User struct {
  gorm.Model
  MemberNumber string
  CreditCards  []CreditCard `gorm:"foreignKey:UserNumber;references:MemberNumber"`
}

type CreditCard struct {
  gorm.Model
  Number     string
  UserNumber string
}

CRUD с has many

Пожалуйста, смотрите режим связей для работы с has many (имеет много) связями

Нетерпеливая загрузка

GORM позволяет использовать нетерпеливую загрузку для связей has many (имеет много) с помощью Preload, смотрите Предзагрузка (Нетерпеливая загрузка) для подробностей

Самосвязанный Has Many

go
type User struct {
  gorm.Model
  Name      string
  ManagerID *uint
  Team      []User `gorm:"foreignkey:ManagerID"`
}

Ограничения внешних ключей

Вы можете настроить OnUpdate, OnDelete ограничения с помощью тега constraint, они будут созданы при миграции с помощью GORM, например:

go
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 для подробностей