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 与另一个模型建立一对一的关联,但它和一对一关系