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="{{.}}" {{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中文网其他相关文章!