首页  >  文章  >  后端开发  >  如何检查 Go 模板中的“sql.Null[Type]”字段是否有效?

如何检查 Go 模板中的“sql.Null[Type]”字段是否有效?

Linda Hamilton
Linda Hamilton原创
2024-10-28 02:36:31413浏览

How to Check if a `sql.Null[Type]` Field is Valid in Go Templates?

测试 Go 模板中的有效字段

在 Go 的 database/sql 包中,Null[Type] 结构有助于将数据库值与潜在的 null 进行映射进入代码。确定结构体字段是否为 null,即其 Valid 属性是否为 false,可能具有挑战性。

要显示 SQL 字段,请使用 .Value 属性:

<code class="go">{{ .MyStruct.MyField.Value }}</code>

当需要更多时复杂的比较,测试该领域的有效性变得很重要。如果 .MyField 无效,则单独使用 if 和 .Value 会导致错误。

尝试使用 and 和或模板函数测试有效字段是否存在也不会成功。即使第一个参数的结果很清楚,计算也不会提前终止。

相反,请考虑使用嵌套的 if 块:

<code class="go">{{if $.MyStruct.MyField}}
    {{if eq $.MyStruct.MyField.Value .}}selected="selected"{{end}}
{{end}}</code>

或者,可以使用 with 块,但是它修改当前模板上下文:

<code class="go">{{range .SomeSlice}}
    {{with $.MyStruct.MyField}}
        {{if eq .Value .}}selected="selected"{{end}}
    {{end}}
{{/range}}</code>

请注意,sql.NullXX 类型是非 nil 结构。要确定其 Value 方法是否返回非零值,请检查其 Valid 字段:

<code class="go">{{if $.MyStruct.MyField.Valid}}
    {{if eq $.MyStruct.MyField.Value .}}selected="selected"{{end}}
{{end}}</code>

以上是如何检查 Go 模板中的“sql.Null[Type]”字段是否有效?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn