25-polymorphism

Polymorphism Association

GORM supports polymorphism association for has one and has many, it will save owned entity’s table name into polymorphic type’s field, primary key value into the polymorphic field

By default polymorphic:<value> will prefix the column type and column id with <value>.
The value will be the table name pluralized.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
type Dog struct {
ID int
Name string
Toys []Toy `gorm:"polymorphic:Owner;"`
}

type Toy struct {
ID int
Name string
OwnerID int
OwnerType string
}

db.Create(&Dog{Name: "dog1", Toys: []Toy{{Name: "toy1"}, {Name: "toy2"}}})
// INSERT INTO `dogs` (`name`) VALUES ("dog1")
// INSERT INTO `toys` (`name`,`owner_id`,`owner_type`) VALUES ("toy1",1,"dogs"), ("toy2",1,"dogs")

You can specify polymorphism properties separately using the following GORM tags:

  • polymorphicType: Specifies the column type.
  • polymorphicId: Specifies the column ID.
  • polymorphicValue: Specifies the value of the type.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
type Dog struct {
ID int
Name string
Toys []Toy `gorm:"polymorphicType:Kind;polymorphicId:OwnerID;polymorphicValue:master"`
}

type Toy struct {
ID int
Name string
OwnerID int
Kind string
}

db.Create(&Dog{Name: "dog1", Toys: []Toy{{Name: "toy1"}, {Name: "toy2"}}})
// INSERT INTO `dogs` (`name`) VALUES ("dog1")
// INSERT INTO `toys` (`name`,`owner_id`,`kind`) VALUES ("toy1",1,"master"), ("toy2",1,"master")

In these examples, we’ve used a has-many relationship, but the same principles apply to has-one relationships.


25-polymorphism
https://flepeng.github.io/021-Go-34-框架-41-Gorm-V2-25-polymorphism/
作者
Go
发布于
2024年12月4日
许可协议