社区微信群开通啦,扫一扫抢先加入社区官方微信群
社区微信群
由于最近项目需要使用mysql,目前go方向比较成熟的就是gorm了。但是在使用表关联和外键的时候,一直查询不到数据,于是就跟了源码。
其主要原因是由于官网上的关联查询,related方法需要第二个参数外键名称,如果没有第二个参数,就需要在你需要设置外键的地方加上一个字段userid。
|
官网文档如下:http://gorm.io/zh_CN/docs/associations.html
例子如下:
package main
import (
_ "github.com/jinzhu/gorm/dialects/mysql"
"github.com/jinzhu/gorm"
"fmt"
)
// 设置User的表名为`profiles`
func (Profile) TableName() string {
return "profile"
}
type Profile struct {
//gorm.Model
ID int `gorm:"primary_key;auto_increment"`
Refer int
Name string
// UserID int /*没有设置第二个参数 需要这个字段*/
}
type User struct {
//gorm.Model
ID int `gorm:"primary_key;auto_increment"`
Company string
Profiles []Profile `gorm:"foreignkey:Refer"`
}
func (User) TableName() string {
return "user"
}
func main() {
db, err := gorm.Open("mysql", "root:9@tcp(localhost:3306)/my")
//db.LogMode(true)
if err != nil {
panic("failed to connect database")
}
defer db.Close()
var u = User{ID: 1, Company: "LejuRobot"}
var e = Profile{Refer: 1, Name: "aaa"}
var e1 = Profile{Refer: 1, Name: "bbb"}
//var e = Profile{Refer: 1, Name: "aaa",UserID: 1}
//var e1 = Profile{Refer: 1, Name: "bbb",UserID: 1}
db.DropTableIfExists(&Profile{})
db.DropTableIfExists(&User{})
db.AutoMigrate(&Profile{}, &User{})
err = db.Create(&u).Error
if err != nil { fmt.Println(err) }
db.Save(&u)
db.Create(&e)
db.Create(&e1)
var s []Profile
var s1 Profile
var us User //关联查询
us.ID = 1
err = db.Model(&us).Related(&s,"refer").Last(&s1).Error
if err != nil { fmt.Println("err", err) } //fmt.Printf("%vn", us) fmt.Println("s", s) fmt.Println("s1:",s1)}
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!