Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk Memadankan Medan Struktur GORM dengan Nama Lajur Pertanyaan?

Bagaimana untuk Memadankan Medan Struktur GORM dengan Nama Lajur Pertanyaan?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-26 05:39:02693semak imbas

How to Match GORM Struct Fields with Query Column Names?

Penamaan Medan Struktur dalam Pengimbasan Pertanyaan GORM

Apabila cuba mengimbas hasil pertanyaan ke dalam struct GORM tersuai, adalah penting untuk diperhatikan konvensyen GORM menggunakan untuk penamaan medan. Secara lalai, GORM menjangkakan medan struct sepadan dengan nama lajur dalam hasil pertanyaan.

Untuk menyelesaikan isu nilai lalai yang anda hadapi, cuba pendekatan berikut:

Pilihan 1: Medan Awam dan Penamaan Betul

  • Pastikan medan struct anda adalah awam dan menggunakan nama yang sama seperti nama lajur dalam hasil pertanyaan. Contohnya:
<code class="go">type Res struct {
    ID     int
    Number int
    UserID int
}</code>

Pilihan 2: Pemetaan Lajur Tersuai

Sebagai alternatif, anda boleh menentukan pemetaan lajur eksplisit menggunakan teg gorm:"column" pada setiap bidang. Ini membolehkan anda menentukan nama lain untuk medan sambil mengekalkan nama lajur asal dalam hasil pertanyaan. Contohnya:

<code class="go">type res struct {
    id int      `gorm:"column:id"`
    number int  `gorm:"column:number"`
    user_id int `gorm:"column:user_id"`
}</code>

Dengan melaksanakan salah satu daripada pilihan ini, anda sepatutnya berjaya mengimbas hasil pertanyaan ke dalam struktur GORM tersuai anda.

Atas ialah kandungan terperinci Bagaimana untuk Memadankan Medan Struktur GORM dengan Nama Lajur Pertanyaan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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