> 백엔드 개발 > Golang > Go 템플릿의 `sql.Null[Type]` 필드 값을 안전하게 비교하는 방법은 무엇입니까?

Go 템플릿의 `sql.Null[Type]` 필드 값을 안전하게 비교하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-10-28 05:36:30
원래의
553명이 탐색했습니다.

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

Go 템플릿에서 유효한 필드 테스트

Go의 데이터베이스/sql 패키지에서 Null[Type] 구조체는 데이터베이스 값을 코드에 매핑하는 것을 용이하게 합니다. 널 지원. 그러나 필드의 nullity(예: Valid 속성이 false인 경우)를 테스트하는 것은 몇 가지 문제를 야기합니다.

SQL 필드를 표시하는 데 권장되는 접근 방식은 다음과 같은 .Value 속성을 사용하는 것입니다.

{{ .MyStruct.MyField.Value }}
로그인 후 복사

값 비교와 관련된 보다 복잡한 시나리오의 경우 .MyField가 유효하지 않으면 접근 방식이 실패하여 "잘못된 비교 유형" 오류가 발생할 수 있습니다. 처음에는 비교하기 전에 .MyField가 nil인지 테스트하는 것이 간단한 해결책처럼 보입니다. 그러나 이 방법은 동일한 오류로 인해 실패합니다.

Go 템플릿의 및 함수는 이러한 상황을 처리할 수 있어야 합니다. 그러나 이전 Go 버전(< 1.18)에서는 단락 평가가 수행되지 않으며 모든 인수가 항상 평가됩니다. 따라서 $.MyStruct.MyField가 nil이면 조건이 false로 평가되더라도 eq $.MyStruct.MyField.Value 입니다. 식이 여전히 평가되어 오류가 발생합니다.

이 문제를 해결하려면 여러 {{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></p>
<p>또한 sql.NullXX 유형은 nil이 될 수 없는 구조체 값이므로 Value() 메서드를 확인하려면 해당 Valid 필드를 확인하는 것이 필수적입니다. nil이 아닌 값을 반환합니다.</p>
<pre class="brush:php;toolbar:false">{{if $.MyStruct.MyField.Valid}}
    {{if eq $.MyStruct.MyField.Value .}}selected="selected"{{end}}
{{end}}
로그인 후 복사

이러한 기술을 사용하면 유효한 필드의 존재 여부를 효과적으로 테스트하고 Go 템플릿에서 해당 값을 비교할 수 있습니다.

위 내용은 Go 템플릿의 `sql.Null[Type]` 필드 값을 안전하게 비교하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿