登录
首页 >  Golang >  Go问答

Gorm 在未找到值时会返回空值而不是默认值

来源:stackoverflow

时间:2024-03-24 15:06:41 191浏览 收藏

使用 Gorm 进行 MySQL 查询时,当查询结果为空时,Gorm 会返回空值,而不是默认值。这种行为可能导致手动检查,以确定查询是否返回了任何内容。为了解决此问题,可以在字段中添加 `json:",omitempty"` 标记,这会在字段包含零值时将其从 JSON 输出中排除。这样,当查询返回空结果时,输出将是一个空的 JSON 对象 `{}`。

问题内容

我在一个小型 go 应用程序中使用 gorm 进行了 mysql 查询。

我已经声明了我的 domain 结构

type domain struct {
    gorm.model
    name string
    ...
}

然后当我使用这种方法通过 gorm 向 mysql 发送查询时。

func domaininfos(w http.responsewriter, r *http.request) {
    vars := mux.vars(r)
    w.writeheader(http.statusok)

    var d domain

    config.dbconnection.where("name = ?", vars["domain"]).find(&d)

    json.newencoder(w).encode(d)
}

当找不到域时,它会从我的结构定义中返回默认对象

{
    {0 0001-01-01 00:00:00 +0000 utc 0001-01-01 00:00:00 +0000 utc } 
    0
    0
    0
}

所以我写了一些条件来手动返回一个空对象

if d.ID == 0 {
    json.NewEncoder(w).Encode(make(map[string]string))
    return
}

gorm是否可以在查询不返回任何内容时直接返回一个空对象,以避免这种手动检查?


解决方案


gorm 正在返回一个空对象;对于 go 值,“空”和“默认”是相同的,实际上称为 zero value。在您的情况下,您需要控制 json 输出,而不是 gorm 返回值。

您可以将 omitempty 标记添加到您的字段中,以便在它们的类型包含零值时将它们从 json 输出中排除:

type domain struct {
    gorm.model
    name string `json:",omitempty"`
    ...
}

对于带有此标记的每个字段,当您调用 encodemarshal 时,如果该字段包含其零值(例如,对于 name,它是一个 string,如果它等于 ""),则该字段将不会被包含在输出中。如果您以这种方式标记所有导出的字段,并且它们都包含零值,则输出将是一个空的 json 对象 {}

另请注意:

json.newencoder(w).encode(make(map[string]string))

相当于,但效率明显低于:

w.write([]byte("{}"))

您的另一个选择是自定义元帅函数,如下所示:

func (d Domain) MarshalJSON() ([]byte, error) {
    if t.ID == 0 {
        return []byte("{}"), nil
    }

    // Wrap the type to avoid infinite recursion on MarshalJSON
    type dd Domain
    return json.Marshal(dd(d))
}

您可以在此处查看工作示例:https://play.golang.org/p/mIRfRKXeyyW

omitempty 不适用于 time.time 类型的结构字段

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

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