首页 > 后端开发 > Golang > 正文

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

Patricia Arquette
发布: 2024-10-28 05:36:30
原创
472 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!