Heim > Backend-Entwicklung > Golang > Wie definiere und verwende ich Fremdschlüsseleinschränkungen in GORM?

Wie definiere und verwende ich Fremdschlüsseleinschränkungen in GORM?

DDD
Freigeben: 2024-12-13 06:12:19
Original
845 Leute haben es durchsucht

How to Define and Use Foreign Key Constraints in GORM?

Wie definiere und verwende ich eine Fremdschlüsseleinschränkung in GORM?

Im Bereich des Datenbankdesigns spielen Fremdschlüssel eine entscheidende Rolle beim Aufbau von Beziehungen und der Aufrechterhaltung der Datenintegrität . Für GORM-Benutzer ist es wichtig zu verstehen, wie Fremdschlüsseleinschränkungen definiert und verwendet werden.

Das Problem verstehen

Betrachten Sie das in der Frage beschriebene Szenario, in dem wir zwei Modelle haben: User und UserInfo. Wir müssen eine Fremdschlüsselbeziehung zwischen dem UID-Feld in UserInfo und dem ID-Feld in User herstellen.

GORMs Fremdschlüsselgenerierung

In GORM-Versionen vor 2.0 mussten wir Fremdschlüssel manuell definieren Schlüsseleinschränkungen mithilfe der AddForeignKey-Methode. In GORM 2.0 und höher ist dieser Schritt nicht mehr erforderlich.

// GORM version 1.x
db.Model(&models.UserInfo{}).AddForeignKey("u_id", "t_user(id)", "RESTRICT", "RESTRICT")
Nach dem Login kopieren

Automatisierte Fremdschlüsseldefinition

Für ältere Versionen von GORM können wir jedoch weiterhin Fremdschlüssel wie unten gezeigt definieren.

type User struct {
    DBBase
    Email    string `gorm:"column:email" json:"email"`
    Password string `gorm:"column:password" json:"-"`
}

func (User) TableName() string {
    return "t_user"
}

type UserInfo struct {
    User      User   `gorm:"foreignkey:u_id;association_foreignkey:id"`
    UID       uint   `gorm:"column:u_id" json:"-"`
    FirstName string `gorm:"column:first_name" json:"first_name"`
    LastName  string `gorm:"column:last_name" json:"last_name"`
    Phone     string `gorm:"column:phone" json:"phone"`
    Address   string `gorm:"column:address" json:"address"`
}

func (UserInfo) TableName() string {
    return "t_user_info"
}
Nach dem Login kopieren

Beachten Sie, dass wir in diesem Beispiel die Fremdschlüsselbeziehung mit den Begriffen:"foreignkey:..." und definieren gorm:"association_foreignkey:..." Anmerkungen.

Fremdschlüsselwerte im Code festlegen

Als nächstes wollen wir uns mit der Frage befassen, wie Fremdschlüsselwerte korrekt festgelegt werden. Im bereitgestellten Code:

func (dao *AuthDAO) Register(rs app.RequestScope, user *models.User, userInfo *models.UserInfo) (userErr error, userInfoErr error) {
    createUser := rs.Db().Create(&user)
    userInfo.UID = user.ID
    createUserInfo := rs.Db().Create(&userInfo)

    return createUser.Error, createUserInfo.Error
}
Nach dem Login kopieren

Wir setzen userInfo.UID auf user.ID, nachdem wir die Benutzerinstanz erstellt haben. Dieser Ansatz ist gültig und stellt die Fremdschlüsselbeziehung korrekt her.

Zusammenfassend lässt sich sagen, dass das Verständnis von Fremdschlüsselbeziehungen und ihrer Implementierung in GORM für die Aufrechterhaltung der Datenintegrität in datenbankgesteuerten Anwendungen von entscheidender Bedeutung ist. Indem Sie die vorgeschlagenen Lösungen und Anmerkungen befolgen, können Sie Fremdschlüsseleinschränkungen in Ihren GORM-Modellen effektiv definieren und nutzen.

Das obige ist der detaillierte Inhalt vonWie definiere und verwende ich Fremdschlüsseleinschränkungen in GORM?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage