首頁 >後端開發 >Golang >如何檢查 Go 模板中的「sql.Null[Type]」欄位是否有效?

如何檢查 Go 模板中的「sql.Null[Type]」欄位是否有效?

Linda Hamilton
Linda Hamilton原創
2024-10-28 02:36:311082瀏覽

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