fix: 修正 player_services 数组字段的 SQL 序列化错误
This commit is contained in:
@@ -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 {
|
||||
|
||||
Reference in New Issue
Block a user