From db62d1262eaebfe9f308e51ea3c3fdb2b5132ec5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=B4=BE=E4=B8=80=E9=A5=BC?= Date: Fri, 27 Jun 2025 18:19:56 +0800 Subject: [PATCH] A little optimization for filed.ValueOf --- schema/field.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/schema/field.go b/schema/field.go index ff4aa7dd..72e4b42b 100644 --- a/schema/field.go +++ b/schema/field.go @@ -455,7 +455,7 @@ func (field *Field) setupValuerAndSetter() { // ValueOf returns field's value and if it is zero fieldIndex := field.StructField.Index[0] switch { - case len(field.StructField.Index) == 1 && fieldIndex > 0: + case len(field.StructField.Index) == 1 && fieldIndex >= 0: field.ValueOf = func(ctx context.Context, value reflect.Value) (interface{}, bool) { fieldValue := reflect.Indirect(value).FieldByName(field.Name) return fieldValue.Interface(), fieldValue.IsZero() @@ -504,7 +504,7 @@ func (field *Field) setupValuerAndSetter() { // ReflectValueOf returns field's reflect value switch { - case len(field.StructField.Index) == 1 && fieldIndex > 0: + case len(field.StructField.Index) == 1 && fieldIndex >= 0: field.ReflectValueOf = func(ctx context.Context, value reflect.Value) reflect.Value { return reflect.Indirect(value).Field(fieldIndex) }