Gorm Preload()方法——在GoLang中处理MySQL一对多关系

高能预警

  • 本文的绝大部分内容来自于 Gorm官方文档,默认读者了解Gorm库
  • 本文基于Gorm v2版本,敬请读者朋友们对应食用~

正文

  • 我们在后台处理数据库一对多的关系时,当然希望“多”的这部分部分数据乖乖的存放在数组中。在Gorm库中已经为我们提供了预加载(Preload()方法)来解决这个问题,本文将带领大家快速上手。请君继续阅读。
数据结构体
  • 这里说明一下,我们使用结构体嵌套的这种方式,并不会对Gorm创建的数据库产生影响,即它不会把下面的Orders []Order解析成字段,更不会自动创建外键(这里可以使用gorm的 标签 来实现更高级的数据库操作),现在想想还是很便捷的。
`源自官网示例`
type User struct {
	Id int
	Username string
	Orders   []Order
}

type Order struct {
	Id int
	UserID uint
	Price  float64
}
初始化表 & 创建数据
func main() {
	// 数据库连接
	dsn := "root:123456@(127.0.0.1:3306)/CSDN?charset=utf8mb4&parseTime=True&loc=Local"
	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		panic(err)
	}

	// 初始化表
	_ = db.AutoMigrate(User{}, Order{})

	// 创建数据
	_ = CreatUser(db)
	_ = CreatOrder(db)
}

func CreatUser(db *gorm.DB) (err error) {
	err = db.Create(&[]User{
		{Username: "little_A"},
		{Username: "little_B"},
		{Username: "little_C"},
		{Username: "little_D"},
	}).Error
	return
}

func CreatOrder(db *gorm.DB) (err error) {
	err = db.Create(&[]Order{
		{UserID: 1, Price: 1},
		{UserID: 1, Price: 2},
		{UserID: 1, Price: 3},
		{UserID: 1, Price: 4},
		{UserID: 2, Price: 5},
		{UserID: 2, Price: 6},
		{UserID: 2, Price: 7},
		{UserID: 3, Price: 8},
		{UserID: 3, Price: 9},
		{UserID: 4, Price: 10},
	}).Error
	return
}
可视化查看一下

users表
orders表

  • 可以看到我们没个user下都对应这一个或多个price,符合一对多的条件。
  • 准备工作就绪后,让我们开始使用Preload()方法。
在main函数中加入并执行
	var a []User
	db.Preload("Orders").Find(&a)
	fmt.Println(a)
控制台输出

控制台输出

  • 可以看到我们是对Users表的查询,Orders表的预加载,一对多的关系一目了然。
后记
  • 本文是博主在处理MySQL一对多关联的理解,当然本文内容是相对基础的,读者们可以根据自己的需求解锁更多高级用法,以上。

感谢阅读。

  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值