Dans le package base de données/sql de Go, les types Null fournissent un mécanisme pour représenter les valeurs de base de données nullables. Déterminer si un champ dans une structure est nul (Valide est faux) peut être difficile dans les expressions de modèle.
Pour imprimer la valeur d'un champ SQL, la propriété .Value est couramment utilisée. Cependant, lors de la comparaison de la valeur d'un champ avec une autre valeur, des problèmes peuvent survenir si le champ est nul. Tester directement nil (par exemple, si $.MyStruct.MyField == nil) ne fonctionnera pas car les champs ne sont pas nuls mais plutôt des structures Null vides.
La fonction and dans les modèles Go évalue tous ses arguments, même si le résultat est déjà déterminé. Par conséquent, utiliser {{ if and ($.MyStruct.MyField) (eq $.MyStruct.MyField.Value .) }} provoquera une erreur si $.MyStruct.MyField est null.
À la place, utilisez des imbriqués Instruction {{ if }} pour évaluer sélectivement les expressions :
{{ if $.MyStruct.MyField }} {{ if eq $.MyStruct.MyField.Value . }}selected="selected"{{ end }} {{ end }}
Vous pouvez également utiliser l'instruction {{ with }}, mais sachez qu'elle définit le point, ce qui nécessite un examen attentif :
{{ with $.MyStruct.MyField }} {{ if eq .Value $e }}selected="selected"{{ end }} {{ end }}
Notez que les exemples ci-dessus supposent des valeurs non nullables. Pour les types Null, vérifiez directement le champ Valide :
{{ if $.MyStruct.MyField.Valid }} {{ if eq $.MyStruct.MyField.Value . }}selected="selected"{{ end }} {{ end }}
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!