Tidak dapat membaca julat json ke dalam pgtype.Int4range

WBOY
Lepaskan: 2024-02-10 09:00:09
ke hadapan
378 orang telah melayarinya

无法将 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)
}
Salin selepas log masuk

Ralat-

Error while unmarshalling JSON: json: cannot unmarshal string into Go struct field TestPreference.health_range of type pgtype.Int4range.
Salin selepas log masuk

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, `"`))
}
Salin selepas log masuk

By the way

assert.equal(t, 20, update.healthrange.lower)
Salin selepas log masuk

Membandingkan dua jenis yang berbeza, hendaklah diperbetulkan kepada:

assert.Equal(t, int32(20), update.HealthRange.Lower.Int)
Salin selepas log masuk
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!

sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!