Rumah > Artikel > pembangunan bahagian belakang > 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!
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?
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!