fix: 修正 player_services 数组字段的 SQL 序列化错误

This commit is contained in:
zetaloop
2026-04-04 01:43:02 +08:00
parent 64223ada67
commit 9bbc54ea66
3 changed files with 15 additions and 12 deletions
@@ -3,9 +3,9 @@
package models
import (
"encoding/json"
"fmt"
"juwan-backend/app/player/rpc/internal/models/playerservices"
"juwan-backend/pkg/types"
"strings"
"time"
@@ -52,7 +52,7 @@ func (*PlayerServices) scanValues(columns []string) ([]any, error) {
for i := range columns {
switch columns[i] {
case playerservices.FieldAvailability:
values[i] = new([]byte)
values[i] = new(types.TextArray)
case playerservices.FieldPrice, playerservices.FieldRating:
values[i] = new(decimal.Decimal)
case playerservices.FieldIsActive:
@@ -129,12 +129,10 @@ func (_m *PlayerServices) assignValues(columns []string, values []any) error {
*_m.RankRange = value.String
}
case playerservices.FieldAvailability:
if value, ok := values[i].(*[]byte); !ok {
if value, ok := values[i].(*types.TextArray); !ok {
return fmt.Errorf("unexpected type %T for field availability", values[i])
} else if value != nil && len(*value) > 0 {
if err := json.Unmarshal(*value, &_m.Availability); err != nil {
return fmt.Errorf("unmarshal field availability: %w", err)
}
} else if value != nil {
_m.Availability = append([]string{}, value.Elements...)
}
case playerservices.FieldRating:
if value, ok := values[i].(*decimal.Decimal); !ok {