普通网友 2018-02-16 16:49
浏览 137
已采纳

Go Gorm没有显示数据有很多

I'm using http://gorm.io/docs/has_many.html to create several entries in one table owned by one team in another.

Team struct {
    ID             int64         `gorm:"primary_key" json:"Id"`
    PayingMemberID sql.NullInt64 `json:"PayingMemberId,int64"`
    PayingMember   *User
    Name           string `json:"Name"`

    Teamcoins          []Teamcoin `gorm:"foreignkey:TeamID"`
}

Teamcoin struct {
    ID     int64 `gorm:"primary_key" json:"Id"`
    Team   Team
    TeamID int64

    PeriodYear  int
    PeriodMonth int

    Coin int `json:"-"`
}

Then, I create an entry in the Team table like this:

teamcoin := Teamcoin{
    PeriodYear:        2018,
    PeriodMonth:       2,
    Coin:              12,
}

team := Team{
    Name : "Some Name",
    Microcoins: []Teamcoin{teamcoin},
}

The result, as expected, creates a team entry with ID. When I run next piece of code to get the info of all teams:

var t []Team
err := r.db.Preload("PayingMember").Find(&t).Error

And I show t, I get: {530071983 {0 false} Some Name { false} 0 0 0 [ ] 0 0 0 false}

Now, I might be omitting some info on the structure of the Team in this post, but anyway, I never get to show the information about the related TeamCoins even that the related information is created in the table.

[ ] is always empty and I'm expecting the TeamCoin information.

  • 写回答

1条回答 默认 最新

  • doufulian4076 2018-02-16 19:09
    关注

    You probably should chain your preloads, do to get all of associacions you need to write

    r.db.Preload("PayingMember").Preload("Teamcoins").Find(&t).Error

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同