首頁 > 後端開發 > Golang > 主體

GORM:使用相同的外鍵定義多個列

WBOY
發布: 2024-02-13 11:45:16
轉載
1055 人瀏覽過

GORM:使用相同的外鍵定義多個列

php小編草今天為大家帶來一個有關GORM的問題:如何在GORM中使用相同的外鍵定義多個欄位?在資料庫設計中,有時我們需要在多個表中使用相同的外鍵列,這就需要我們在GORM中進行適當的定義和配置。接下來,我們將詳細介紹如何在GORM中實現這項需求,以及相關的注意事項。讓我們一起來探索這個有趣的主題吧!

問題內容

我正在建立一個使用 GORM 的 Golang MySQL 專案。我有一個名為accounts 的表,其中包含欄位

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"`
登入後複製

現在我想製作一個名為帶有欄位的交易的表格

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
登入後複製

我不知道如何在 go Gorm 中定義它?我可以有兩個帶有外鍵的字段到另一個表的同一列嗎?如何做到這一點?

解決方法

是用這個做的嗎?謝謝!

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"`
}
登入後複製

以上是GORM:使用相同的外鍵定義多個列的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!