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

GORM: Tentukan berbilang lajur dengan kunci asing yang sama

WBOY
WBOYke hadapan
2024-02-13 11:45:161083semak imbas

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"`

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

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"`
}

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!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam