Rumah >pembangunan bahagian belakang >Golang >Tidak dapat membaca julat json ke dalam pgtype.Int4range
editor php Baicao mungkin menghadapi mesej ralat apabila menggunakan pangkalan data PHP dan PostgreSQL: "Tidak dapat membaca julat json sebagai pgtype.Int4range". Ralat ini biasanya berlaku apabila cuba menukar jenis data JSON kepada jenis data pgtype.Int4range. Penyelesaian kepada masalah ini tidak rumit Anda hanya perlu menukar data JSON kepada rentetan dan kemudian melakukan penukaran jenis data. Seterusnya, kami akan terperinci bagaimana untuk menyelesaikan masalah ini.
Saya cuba membaca julat ke dalam json tetapi saya menghadapi masalah melakukan json.unmarshal.
Ini adalah kod ujian-
import ( "encoding/json" "testing" "github.com/jackc/pgtype" "github.com/stretchr/testify/assert" ) type testhealthpreference struct { healthrange pgtype.int4range `json:"health_range"` id string `json:"id"` } // just a test to make sure unmarshaling works func testpreferenceupdateunmarshal(t *testing.t) { jsondata := `{ "health_range": "[20,30)", "id": "123" }` var update testhealthpreference err := json.unmarshal([]byte(jsondata), &update) if err != nil { t.errorf("error while unmarshalling json: %v", err) } assert.equal(t, 20, update.healthrange.lower) }
Ralat-
Error while unmarshalling JSON: json: cannot unmarshal string into Go struct field TestPreference.health_range of type pgtype.Int4range.
Adakah mungkin untuk membacanya sebagai pgtype.int4range? Saya rasa jenis ini adalah untuk penggunaan pangkalan data sahaja? fwiw, saya menggunakan pgx github.com/jackc/pgx/v4
Ia tidak berfungsi kerana "[20,30)"
不是结构 pgtype.int4range
mempunyai nilai json yang sah dan pgtype.int4range tidak melaksanakan antara muka json.unmarsha belum lagi.
:"[20,30)"
type myint4range pgtype.int4range func (r *myint4range) unmarshaljson(b []byte) error { return (*pgtype.int4range)(r).decodetext(nil, bytes.trim(b, `"`)) }By the way
assert.equal(t, 20, update.healthrange.lower)Membandingkan dua jenis yang berbeza, hendaklah diperbetulkan kepada:
assert.Equal(t, int32(20), update.HealthRange.Lower.Int)Lihat demo penuh di sini:
https://www.php.cn/link/fbf6e9ffad68f73e466198206987dedc.一个>
Atas ialah kandungan terperinci Tidak dapat membaca julat json ke dalam pgtype.Int4range. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!