首页  >  文章  >  后端开发  >  如何安全地比较 Go 模板中“sql.Null[Type]”字段的值?

如何安全地比较 Go 模板中“sql.Null[Type]”字段的值?

Patricia Arquette
Patricia Arquette原创
2024-10-28 05:36:30464浏览

How to  Safely Compare Values from  `sql.Null[Type]` Fields in Go Templates?

Go 模板中的有效字段测试

在 Go 的 database/sql 包中,Null[Type] 结构有助于将数据库值映射到代码空支持。然而,测试字段的无效性(即,当其 Valid 属性为 false 时)会带来一些挑战。

显示 SQL 字段的推荐方法是通过 .Value 属性,例如:

{{ .MyStruct.MyField.Value }}

对于涉及值比较的更复杂场景,如果 .MyField 无效,该方法可能会失败,从而导致“比较类型无效”错误。最初,在进行比较之前测试 .MyField 是否为零似乎是一个简单的解决方案。然而,这个方法失败并出现同样的错误。

Go 模板中的 and 函数应该能够处理这种情况。然而,在早期的 Go 版本(

要解决此问题,您可以使用多个 {{if}} 操作:

{{if $.MyStruct.MyField}}
    {{if eq $.MyStruct.MyField.Value .}}selected="selected"{{end}}
{{end}}

或者,您可以使用 {{with} } 操作,尽管它设置了点并需要小心:

<select name="y">
   {{range $idx, $e := .SomeSlice}}
       <option value="{{.}}&quot; {{with $.MyStruct.MyField}}
               {{if eq .Value $e}}selected="selected"{{end}}
           {{end}}>{{.}}</option>
   {{end}}
</select>

此外,由于 sql.NullXX 类型是不能为 nil 的结构体值,因此检查其 Valid 字段对于确定其 Value() 方法是否有效至关重要将返回一个非零值:

{{if $.MyStruct.MyField.Valid}}
    {{if eq $.MyStruct.MyField.Value .}}selected="selected"{{end}}
{{end}}

这些技术允许您有效地测试有效字段是否存在并比较它们在 Go 模板中的值。

以上是如何安全地比较 Go 模板中“sql.Null[Type]”字段的值?的详细内容。更多信息请关注PHP中文网其他相关文章!

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