Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Tidak dapat membaca julat json ke dalam pgtype.Int4range

Tidak dapat membaca julat json ke dalam pgtype.Int4range

WBOY
WBOYke hadapan
2024-02-10 09:00:09376semak imbas

无法将 json 范围读取为 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.

Kandungan soalan

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

Penyelesaian

Ia tidak berfungsi kerana "[20,30)" 不是结构 pgtype.int4range mempunyai nilai json yang sah dan pgtype.int4range tidak melaksanakan antara muka json.unmarsha belum lagi.

Anda mesti melaksanakan sendiri antara muka untuk membongkar

:"[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!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam