登录
首页 >  Golang >  Go问答

如何创建在列中包含切片的表

来源:stackoverflow

时间:2024-04-07 20:03:33 192浏览 收藏

怎么入门Golang编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《如何创建在列中包含切片的表》,涉及到,有需要的可以收藏一下

问题内容

我有一个如下所示的模型:

type Inventory struct {
    gorm.Model
    LocationID string
    Items      []Item //this is a slice of structs
    Categories []Category //this is a slice of structs
}

当我使用 gorm 为其创建表时,我没有项目或类别列。 我缺少什么?


解决方案


由于 sql 中不支持数组(至少大多数版本的 sql),gorm 不会为切片类型的字段创建列。

但是,您可以使用关联创建您现在的关系结构。在这种情况下,has-manymany-to-many 都是合适的(我无法从这个例子中看出,尽管可能有很多)。

这些工作原理是为这些嵌套对象创建单独的表。在多对多关系中,将为项目和类别创建一个单独的表,每个表都有一个对库存表的外键引用。多对多的情况类似,但使用连接表而不是简单的外键。

例如(有很多):

type Inventory struct {
    gorm.Model
    LocationID string
    Items      []Item //this is a slice of structs
    Categories []Category //this is a slice of structs
}

type Item struct {
    // ...
    InventoryId uint
}

type Category struct {
    // ...
    InventoryId uint
}

db.Model(&inventory).Related(&items)
db.Model(&inventory).Related(&categories)

终于介绍完啦!小伙伴们,这篇关于《如何创建在列中包含切片的表》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>