普通网友 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 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)
  • ¥15 机器人轨迹规划相关问题
  • ¥15 word样式右侧翻页键消失