diff --git a/clients/bigquery/storagewrite.go b/clients/bigquery/storagewrite.go index e8e5934db..7f6ea1354 100644 --- a/clients/bigquery/storagewrite.go +++ b/clients/bigquery/storagewrite.go @@ -2,6 +2,7 @@ package bigquery import ( "fmt" + "strconv" "time" "cloud.google.com/go/bigquery/storage/apiv1/storagepb" @@ -136,6 +137,12 @@ func rowToMessage(row map[string]any, columns []columns.Column, messageDescripto message.Set(field, protoreflect.ValueOfFloat64(float64(value))) case int64: message.Set(field, protoreflect.ValueOfFloat64(float64(value))) + case string: + floatValue, err := strconv.ParseFloat(value, 64) + if err != nil { + return nil, fmt.Errorf("failed to parse string to float64: %w", err) + } + message.Set(field, protoreflect.ValueOfFloat64(float64(floatValue))) default: return nil, fmt.Errorf("expected float32/float64/int32/int64 recieved %T with value %v", value, value) } diff --git a/clients/bigquery/storagewrite_test.go b/clients/bigquery/storagewrite_test.go index 53c83a268..ceaf26168 100644 --- a/clients/bigquery/storagewrite_test.go +++ b/clients/bigquery/storagewrite_test.go @@ -106,6 +106,9 @@ func TestRowToMessage(t *testing.T) { columns.NewColumn("c_int64", typing.Integer), columns.NewColumn("c_float32", typing.Float), columns.NewColumn("c_float64", typing.Float), + columns.NewColumn("c_float_int32", typing.Float), + columns.NewColumn("c_float_int64", typing.Float), + columns.NewColumn("c_float_string", typing.Float), columns.NewColumn("c_numeric", typing.EDecimal), columns.NewColumn("c_string", typing.String), columns.NewColumn("c_string_decimal", typing.String), @@ -123,6 +126,9 @@ func TestRowToMessage(t *testing.T) { "c_int64": int64(1234), "c_float32": float32(1234.567), "c_float64": float64(1234.567), + "c_float_int32": int32(1234), + "c_float_int64": int64(1234), + "c_float_string": "4444.55555", "c_numeric": decimal.NewDecimal(nil, 5, big.NewFloat(3.1415926)), "c_string": "foo bar", "c_string_decimal": decimal.NewDecimal(nil, 5, big.NewFloat(1.618033)), @@ -149,6 +155,9 @@ func TestRowToMessage(t *testing.T) { "cBool": true, "cFloat32": 1234.5670166015625, "cFloat64": 1234.567, + "cFloatInt32": 1234.0, + "cFloatInt64": 1234.0, + "cFloatString": 4444.55555, "cInt": "1234", "cInt32": "1234", "cInt64": "1234",