登录
首页 >  Golang >  Go问答

避免 gorm 堆栈溢出的方法

来源:stackoverflow

时间:2024-02-27 08:27:27 195浏览 收藏

一分耕耘,一分收获!既然都打开这篇《避免 gorm 堆栈溢出的方法》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!

问题内容

首先,使用 sqlite3 test.db < schema.sql 创建数据库。

schema.sql 的内容:

create table x (
    id   integer primary key,
    name text
);

create table y (
    id   integer primary key,
    name text,
    x_id integer references x
);

然后使用 go run main.go 运行程序。

main.go 的内容:

package main

import (
    "gorm.io/gorm"
    "gorm.io/driver/sqlite"
)

type X struct {
    ID   uint
    Name string
    Ys   []*Y
}

type Y struct {
    ID   uint
    Name string
    X    *X     `gorm:"column:x_id"`
}

func (X) TableName() string {
    return "x"
}

func (Y) TableName() string {
    return "y"
}

func main() {
    db, _ := gorm.Open(sqlite.Open("test.db"), &gorm.Config{})

    x := &X{Name: "X"}
    y := &Y{Name: "Y", X: x}
    x.Ys = []*Y{y}

    db.Create(&x)
}

之后 致命错误:堆栈溢出 被抛出。

我想这与所涉及的结构和对象的递归性质有关。当我注释掉 ys []*y 行以及 y := &y{name: "y", x: x}x.ys = []*y{y} 时,它成功地将“x”插入表中x,但是当我仅注释掉 ys []*yx.ys = []*y{y} 并将 db.create(&x) 更改为 db.create(&y) 时,任何一个表中都不会插入任何内容.

编辑

y := &y{name: "y", x: x} 更改为 y := &y{name: "y"} 时,它会保存 xy,但 x_idnullzqbendcz qb.


正确答案


实现 valuer 接口就成功了。

func (x X) Value() (driver.Value, error) {
    return int64(x.ID), nil
}

https://gorm.io/docs/data_types.html

到这里,我们也就讲完了《避免 gorm 堆栈溢出的方法》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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