登录
首页 >  Golang >  Go问答

将 Golang JSON 存储到 Postgresql 中

来源:Golang技术栈

时间:2023-03-30 11:44:30 147浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《将 Golang JSON 存储到 Postgresql 中》,聊聊golang,我们一起来看看吧!

问题内容

我想将某个结构存储到我的数据库中,其中包含一个 JSON 字段。

type Comp struct {
    CompId               int64           `db:"comp_id" json:"comp_id"`
    StartDate            time.Time       `db:"start_date" json:"start_date"`
    EndDate              time.Time       `db:"end_date" json:"end_date"`
    WeeklySchedule       json.RawMessage `db:"weekly_schedule" json:"weekly_schedule"`
}

该表的架构是:

CREATE TABLE IF NOT EXISTS Tr.Comp(
    comp_id                 SERIAL,
    start_date              timestamp NOT NULL,
    end_date                timestamp NOT NULL,
    weekly_schedule         json NOT NULL,
    PRIMARY KEY (comp_id)
);

我在我的项目中使用 sqlx 和 lib/pq 驱动程序,以下将不会执行。相反,它会惊慌失措地说有一个 nil 指针。DB 是一个全局*sqlx.DB结构

    tx := DB.MustBegin()

    compFixture := Comp{
        StartDate:            time.Now(),
        EndDate:              time.Now().AddDate(1, 0, 0),
        WeeklySchedule:       json.RawMessage([]byte("{}")),
    }
    _, err = tx.NamedExec(
        `INSERT INTO 
            Tr.Comp(comp_id, 
                start_date, end_date, weekly_schedule) 
            VALUES (DEFAULT, 
                :start_date, :end_date, :weekly_schedule)  
            RETURNING comp_id;`, compFixture)
    if err != nil {
        t.Fatal("Error creating fixture.", err)
    }

当我weekly_schedule从架构和固定装置中删除时,一切运行良好。但是由于某种原因,当包含此字段时,程序会出现恐慌。weekly_schedule关于我应该如何在我的 DB 模式和 Go 结构中定义该字段的任何想法?

正确答案

sqlx 有一个类型可以满足你JSONText的需要github.com/jmoiron/sqlx/types

JSONText的文档

今天关于《将 Golang JSON 存储到 Postgresql 中》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于golang的内容请关注golang学习网公众号!

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