目錄
問題內容
解決方法
首頁 後端開發 Golang 無法將 json 範圍讀取為 pgtype.Int4range

無法將 json 範圍讀取為 pgtype.Int4range

Feb 10, 2024 am 09:00 AM

无法将 json 范围读取为 pgtype.Int4range

php小編百草在使用PHP與PostgreSQL資料庫時,可能會遇到一個錯誤提示:「無法將 json 範圍讀取為 pgtype.Int4range」。這個錯誤通常發生在嘗試將JSON資料型別轉換為pgtype.Int4range資料型別時。這個問題的解決方法並不複雜,只需要將JSON資料轉換為字串,然後再進行資料類型轉換。接下來,我們將詳細介紹如何解決這個問題。

問題內容

我正在嘗試將範圍讀取為 json,但在執行 json.unmarshal 時遇到問題。

這是一個測試程式碼-

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)
}
登入後複製

錯誤-

Error while unmarshalling JSON: json: cannot unmarshal string into Go struct field TestPreference.health_range of type pgtype.Int4range.
登入後複製

是否可以將其讀取為 pgtype.int4range?我猜這種類型僅供資料庫使用? fwiw,我正在使用pgx github.com/jackc/pgx/v4

解決方法

它不起作用,因為"[20,30)" 不是結構pgtype.int4range 的有效json 值,且pgtype.int4range 尚未實作json.unmarshaler 介面。

您必須自己實作介面來解組 "[20,30)":

type myint4range pgtype.int4range

func (r *myint4range) unmarshaljson(b []byte) error {
    return (*pgtype.int4range)(r).decodetext(nil, bytes.trim(b, `"`))
}
登入後複製

順便說一句

assert.equal(t, 20, update.healthrange.lower)
登入後複製

比較兩種不同的類型,應更正為:

assert.Equal(t, int32(20), update.HealthRange.Lower.Int)
登入後複製

在此處查看完整演示:https://www.php.cn/link/fbf6e9ffad68f73e466198206987dedc一个>.

以上是無法將 json 範圍讀取為 pgtype.Int4range的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Go語言包導入:帶下劃線和不帶下劃線的區別是什麼? Go語言包導入:帶下劃線和不帶下劃線的區別是什麼? Mar 03, 2025 pm 05:17 PM

Go語言包導入:帶下劃線和不帶下劃線的區別是什麼?

如何編寫模擬對象和存根以進行測試? 如何編寫模擬對象和存根以進行測試? Mar 10, 2025 pm 05:38 PM

如何編寫模擬對象和存根以進行測試?

Beego框架中NewFlash()函數如何實現頁面間短暫信息傳遞? Beego框架中NewFlash()函數如何實現頁面間短暫信息傳遞? Mar 03, 2025 pm 05:22 PM

Beego框架中NewFlash()函數如何實現頁面間短暫信息傳遞?

如何使用跟踪工具了解GO應用程序的執行流? 如何使用跟踪工具了解GO應用程序的執行流? Mar 10, 2025 pm 05:36 PM

如何使用跟踪工具了解GO應用程序的執行流?

如何定義GO中仿製藥的自定義類型約束? 如何定義GO中仿製藥的自定義類型約束? Mar 10, 2025 pm 03:20 PM

如何定義GO中仿製藥的自定義類型約束?

Go語言中如何將MySQL查詢結果List轉換為自定義結構體切片? Go語言中如何將MySQL查詢結果List轉換為自定義結構體切片? Mar 03, 2025 pm 05:18 PM

Go語言中如何將MySQL查詢結果List轉換為自定義結構體切片?

Go語言如何便捷地寫入文件? Go語言如何便捷地寫入文件? Mar 03, 2025 pm 05:15 PM

Go語言如何便捷地寫入文件?

我如何使用襯里和靜態分析工具來提高GO代碼的質量和可維護性? 我如何使用襯里和靜態分析工具來提高GO代碼的質量和可維護性? Mar 10, 2025 pm 05:38 PM

我如何使用襯里和靜態分析工具來提高GO代碼的質量和可維護性?

See all articles