我创建了一个要点(https://gist.github.com/carbocation/51b55297702c7d30d3ef),它展示了解决此问题的一种方法。您需要schema.Converter
为四种类型中的每一种创建一个:sql.NullString、sql.NullBool、sql.NullInt64 和 sql.NullFloat64。
sql.NullString 的示例:
import "database/sql"
import "reflect"
func ConvertSQLNullString(value string) reflect.Value {
v := sql.NullString{}
if err := v.Scan(value); err != nil {
return reflect.Value{}
}
return reflect.ValueOf(v)
}
Run Code Online (Sandbox Code Playgroud)
然后将其注册到您的*schema.Decoder
(通常是全局包,在本例中名为d
):
import "database/sql"
nullString := sql.NullString{}
d.RegisterConverter(nullString, ConvertSQLNullString)
Run Code Online (Sandbox Code Playgroud)