Rumah > pembangunan bahagian belakang > Golang > GORM: Tentukan berbilang lajur dengan kunci asing yang sama

GORM: Tentukan berbilang lajur dengan kunci asing yang sama

WBOY
Lepaskan: 2024-02-13 11:45:16
ke hadapan
1118 orang telah melayarinya

GORM: Tentukan berbilang lajur dengan kunci asing yang sama

editor php Baicao membawakan anda soalan tentang GORM hari ini: Bagaimana untuk menggunakan kunci asing yang sama untuk menentukan berbilang lajur dalam GORM? Dalam reka bentuk pangkalan data, kadangkala kita perlu menggunakan lajur kunci asing yang sama dalam berbilang jadual, yang memerlukan kita membuat takrifan dan konfigurasi yang sesuai dalam GORM. Seterusnya, kami akan memperkenalkan secara terperinci cara melaksanakan keperluan ini dalam GORM, serta pertimbangan yang berkaitan. Mari kita terokai topik menarik ini bersama-sama!

Kandungan soalan

Saya sedang mencipta projek Golang MySQL menggunakan GORM. Saya mempunyai jadual yang dipanggil akaun yang mengandungi medan

ID        uint      `json:"id" gorm:"primary_key;auto_increment;not_null"`
    Name      string    `json:"name"`
    Company   string    `json:"company"`
    GSTIN     string    `json:"gstin"`
    AccountNo string    `json:"accountNo" gorm:"unique"`
    IFSC      string    `json:"ifsc"`
    CreatedAt time.Time `json:"createdAt"`
    UpdatedAt time.Time `json:"updatedAt"`
Salin selepas log masuk

Sekarang saya ingin membuat jadual yang dipanggil Transaksi dengan medan

ID            uint      `json:"id" gorm:"primary_key;auto_increment;not_null"`
    Amount        float64   `json:"amount"`
    CreatedAt     time.Time `json:"createdAt"`
    UpdatedAt     time.Time `json:"updatedAt"`
    Date          time.Time `json:"Date"`
    PaymentMode   string    `json:"paymentMode"`
    SourceId      uint      `json:"source"`   ------>>>>> Want this to be AccountID foreign key
    UTR           string    `json:"utr" gorm:"uniqueIndex"`
    DestinationId uint      `json:"to"`       ------>>>>> Want this to be AccountID foreign key
    Account       Account
Salin selepas log masuk

Saya tidak tahu bagaimana untuk mentakrifkannya dalam go Gorm? Bolehkah saya mempunyai dua medan dengan kunci asing pada lajur yang sama pada jadual lain? Bagaimana untuk melakukan ini?

Penyelesaian

Adakah ini digunakan? Terima kasih!

type Debit struct {
    ID                 uint      `json:"id" gorm:"primary_key;auto_increment;not_null"`
    Amount             float64   `json:"amount"`
    CreatedAt          time.Time `json:"createdAt"`
    UpdatedAt          time.Time `json:"updatedAt"`
    PaymentMode        string    `json:"paymentMode"`
    SourceId           uint      `json:"sourceId"`
    UTR                string    `json:"utr" gorm:"uniqueIndex"`
    DestinationId      uint      `json:"destinationId"`
    SourceAccount      Account   `gorm:"foreignKey:SourceId"`
    DestinationAccount Account   `gorm:"foreignKey:DestinationId"`
}
Salin selepas log masuk

Atas ialah kandungan terperinci GORM: Tentukan berbilang lajur dengan kunci asing yang sama. 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