Bootstrap

go操作mysql创建多对多_gorm 关系一对一,一对多,多对多查询

gorm 关系一对一,一对多,多对多查询

gorm v2版本

Belongs To

mysql表

CREATE TABLE `user` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(64) NOT NULL DEFAULT '',

`c_sn` int(11) NOT NULL DEFAULT '0',

`created_at` datetime(3) DEFAULT NULL,

`updated_at` datetime(3) DEFAULT NULL,

`deleted_at` datetime(3) DEFAULT NULL,

PRIMARY KEY (`id`) USING BTREE,

KEY `index_casusers_on_cas_uid` (`cas_uid`) USING BTREE,

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

CREATE TABLE `company` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(64) NOT NULL DEFAULT '',

`c_sn` int(11) NOT NULL DEFAULT '0',

PRIMARY KEY (`id`) USING BTREE,

KEY `index_c_sn` (`c_sn`) USING BTREE,

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

belongs to 会与另一个模型建立了一对一的连接。 这种模型的每一个实例都 “属于” 另一个模型的一个实例。

例如,您的应用包含 user 和 company,并且每个 user 都可以分配给一个 company

主表与其它表建立关连(关链关系字段存到主表)

// `User` 属于 `Company`,`CompanyID` 是外键

type User struct {

gorm.Model

Name string

CompanyID int

Company Company

}

type Company struct {

ID int

Name string

}

重写外键: foreignKey:company_sn (指定user表里的company_sn)

User表外键默认关联Company的主键id ,可以重写成其它外键,如Company里的c_sn字段

重写引用: references:c_sn (指定company_表里的c_sn)

指定user表里的company_sn字段关联company_表里的c_sn

写法一:和mysql里的字段字写成一样的

gorm:"foreignKey:company_sn;references:c_sn"

写法一:和结构体里key名写成一样的

gorm:"foreignKey:CompanySn;references:CSn"

// `User` 属于 `Company`,`CompanyID` 是外键

type User struct {

gorm.Model

Name string string `json:"name"`

CompanySn string `json:"company_sn"` //关连接company表

Company Company `json:"casusers" gorm:"foreignKey:company_sn;references:c_sn"`

}

type Company struct {

ID int `json:"ID"`

Name string `json:"name"`

CSn string `json:"cSn"`

}

// 查找 user 时预加载相关 Company

db.Joins("Company").First(&user, 1)

// 查找 user 时预加载相关 Company

db.Preload("Company").Find(&users)

Has One

mysql表

CREATE TABLE `user` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(64) NOT NULL DEFAULT '',

`created_at` datetime(3) DEFAULT NULL,

`updated_at` datetime(3) DEFAULT NULL,

`deleted_at` datetime(3) DEFAULT NULL,

PRIMARY KEY (`id`) USING BTREE,

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

CREATE TABLE `credit_card ` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`number` varchar(64) NOT NULL DEFAULT '',

`user_name` varchar(64) NOT NULL DEFAULT '',

`created_at` datetime(3) DEFAULT NULL,

`updated_at` datetime(3) DEFAULT NULL,

`deleted_at` datetime(3) DEFAULT NULL,

PRIMARY KEY (`id`) USING BTREE,

KEY `index_number` (`number`) USING BTREE,

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

has one 与另一个模型建立一对一的关联,但它和一对一关系

;