Rumah > pembangunan bahagian belakang > Golang > Pergi - Cara yang betul untuk menggunakan pgtypes

Pergi - Cara yang betul untuk menggunakan pgtypes

PHPz
Lepaskan: 2024-02-13 22:18:10
ke hadapan
1302 orang telah melayarinya

Go - 使用 pgtypes 的正确方法

Editor PHP Xigua hari ini memperkenalkan anda kepada kaedah yang betul untuk menggunakan pgtypes, yang sangat penting untuk pembangun yang menggunakan bahasa Go untuk pengaturcaraan pangkalan data PostgreSQL. pgtypes ialah perpustakaan bahasa Go yang menyediakan fungsi penukaran dan pemprosesan kepada dan dari jenis pangkalan data PostgreSQL. Penggunaan pgtypes yang betul boleh mengelakkan ralat dan pengecualian apabila berurusan dengan jenis pangkalan data, di samping meningkatkan kebolehbacaan dan kebolehselenggaraan kod anda. Dalam artikel ini, kami akan memperincikan cara menggunakan pgtypes dengan betul, serta beberapa pertimbangan biasa dan amalan terbaik. Jika anda seorang pembangun yang menggunakan bahasa Go untuk pengaturcaraan pangkalan data PostgreSQL, sila teruskan membaca, saya percaya artikel ini akan membantu anda.

Kandungan soalan

Saya sedang membangunkan jenis Go 服务来连接到数据库进行基本查询。我正在使用 sqlc 生成 Go 函数来与数据库交互。当将驱动程序从 lib/pq 切换到 pgx/v5 时,现在数据库字段的类型是 pgtypes 而不是 Go yang mudah. Berikut adalah contoh:

bukan ini:

type ListAccountsParams struct {
        Owner  string `json:"owner"`
        Limit  int32  `json:"limit"`
        Offset int32  `json:"offset"`
    }
Salin selepas log masuk

Saya faham sekarang:

type ListAccountsParams struct {
        Owner  pgtype.Text `json:"owner"`
        Limit  pgtype.Int4 `json:"limit"`
        Offset pgtype.Int4 `json:"offset"`
    }
Salin selepas log masuk

Tetapi satu-satunya cara yang saya dapati untuk menggunakan pgtypes ialah ini:

owner := pgtype.Text{
        String: "Craigs List",
        Valid: true,
    }
Salin selepas log masuk

bukan hanya melaksanakan owner := "Craigs List". Untuk jenis angka ia lebih berlebihan, semua pelaksanaan yang saya temui kelihatan seperti ini:

pgtype.Numeric{
    Int: big.NewInt(-543), 
    Exp: 3, 
    Status: pgtype.Present
    }
Salin selepas log masuk

Tiada gunanya menggunakan sqlc 配置文件,我可以覆盖这些类型以支持 Go 标准类型,但是对我来说必须将 postgres text 类型覆盖为 string dll...

Pada pendapat saya ini bukan cara terbaik untuk menggunakan jenis ini, ia berlawanan dengan intuisi saya. Jadi persoalan saya, adakah saya melakukannya dengan betul? Adakah terdapat pendekatan yang berbeza? Akhirnya, adakah cara untuk mengkonfigurasi sqlc untuk menggunakan jenis Go dan bukannya sqlc 使用 Go 类型而不是 pgtypes,同时仍然使用 pgx/v5 驱动程序?

解决方法

您可以编辑 sqlc 配置文件,为要使用 Go 类型而不是 pgtype 类型的字段指定自定义类型,并通过在 sqlc.yaml semasa masih menggunakan pemacu pgx/v5?

Penyelesaianpgtype< /p>Anda boleh mengedit fail konfigurasi sqlc untuk menentukan jenis tersuai untuk medan yang anda mahu gunakan jenis Go dan bukannya

jenis, dan konfigurasikannya dalam sqlc.yaml< /code> fail Gantikan jenis dengan menyatakan jenis Go yang diperlukan dalam <strong> <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;">types: - name: ListAccountsParams fields: - name: Owner goType: string - name: Limit goType: int32 - name: Offset goType: int32</pre><div class="contentsignin">Salin selepas log masuk</div></div> Sila ambil perhatian bahawa menggunakan jenis Go secara langsung boleh menyebabkan kemungkinan jenis tidak sepadan atau isu lain apabila berinteraksi dengan pangkalan data, manakala jenis direka khusus untuk mengendalikan jenis data khusus PostgreSQL dan memberikan tahap keselamatan dan keserasian jenis tertentu! <p> <code>pgx/v5 驱动程序与 sqlc 一起使用时,生成的代码使用 pgtype 类型来处理 PostgreSQL 特定的数据类型,这是 sqlc 在使用 pgx/v5 驱动程序时的默认行为,以及方式您描述的使用 pgtype 类型,例如 pgtype.Textpgtype.Int4,是处理这些类型的正确方法,例如,在处理 pgtype.Text 类型时,您需要将 String 字段设置为所需的值,并将 Valid 字段设置为 true

Dikemas kini

pgtype.Numeric类型需要设置IntExpStatus字段,这是因为pgtype.Numeric类型表示一个任意精度整数的数值(Int) ), 指数(Exp),以及一个状态(Status

Mengikut ulasan anda, apabila menggunakan pemacu pgx/v5 dengan sqlc, kod yang dihasilkan menggunakan 🎜 jenis untuk mengendalikan jenis data khusus PostgreSQL, iaitu sqlc apabila menggunakan pemacu pgx/v5 dan cara anda menerangkan menggunakan 🎜 jenis, seperti pgtype.Teks dan pgtype.Int4 , ialah cara yang betul untuk mengendalikan jenis ini, contohnya apabila mengendalikan jenis pgtype.Teks anda perlu menetapkan medan String kepada nilai yang diperlukan dan tetapkan medan Sah kepada true. 🎜 🎜Untuk jenis angka, 🎜), menunjukkan sama ada nilai itu wujud atau kosong! 🎜

Atas ialah kandungan terperinci Pergi - Cara yang betul untuk menggunakan pgtypes. 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