Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/postgresql/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Postgresql 去解决许多问题_Postgresql_Go_Foreign Keys_Many To Many_Go Gorm - Fatal编程技术网

Postgresql 去解决许多问题

Postgresql 去解决许多问题,postgresql,go,foreign-keys,many-to-many,go-gorm,Postgresql,Go,Foreign Keys,Many To Many,Go Gorm,我无法找到向模型添加关联的最佳方法。我有以下结构 type Beer struct { ID uint `json:"id"` Name string `json:"name" gorm:"not null;" sql:"unique"` Description string `json:"description" gorm:"not null;"` ImageURL

我无法找到向模型添加关联的最佳方法。我有以下结构

type Beer struct {
        ID             uint       `json:"id"`
    Name           string     `json:"name" gorm:"not null;" sql:"unique"`
    Description    string     `json:"description" gorm:"not null;"`
    ImageURL       string     `json:"image_url"`
    AlcoholContent float64    `json:"alcohol_content, default:0"`
    Featured       bool       `json:"featured"`
    BrewStart      time.Time  `json:"brew_start"`
    BrewEnd        time.Time  `json:"brew_end"` 
    Brewers        []Brewer   `gorm:"many2many:beer_brewers" json:"brewers"`
}

type Brewer struct {
    ID        uint       `json:"id"`
    FirstName string     `json:"first_name"`
    LastName  string     `json:"last_name"`
    Title     string     `json:"title"`
    Featured  bool       `json:"featured"`
    Beers     []Beer    `gorm:"many2many:beer_brewers" json:"beers"`
}
下面是我在数据库中植入的数据示例

Beer{
    Name:           "some pale ale",
    Description:    "a description of some pale ale",
    ImageURL:       "http://via.placeholder.com/350x150",
    AlcoholContent: 4.5,
    Featured:       false,
    BrewStart:      utils.ParseTime("30-10-2017 13:00 (AEDT)"),
    BrewEnd:        utils.ParseTime("14-11-2017 13:00 (AEDT)"),
    Brewers: []Brewer{
        Brewer{FirstName: "john", LastName: "smith", Title: "bottle shaker", Featured: false},
        Brewer{FirstName: "joe", LastName: "bloggs", Title: "bottle maker", Featured: true},
    },
},
Beer{
    Name:           "some lager",
    Description:    "a description of some pale ale",
    ImageURL:       "http://via.placeholder.com/350x150",
    AlcoholContent: 4.5,
    Featured:       false,
    BrewStart:      utils.ParseTime("30-10-2017 13:00 (AEDT)"),
    BrewEnd:        utils.ParseTime("14-11-2017 13:00 (AEDT)"),
    Brewers: []Brewer{
        Brewer{FirstName: "john", LastName: "smith", Title: "bottle shaker", Featured: false},
        Brewer{FirstName: "joe", LastName: "bloggs", Title: "bottle maker", Featured: true},
    },
},
但是,上面的操作会在Brewer表中创建重复的Brewer。我的问题是,引用一个已经存在但不在Brewer表中创建另一个Brewer项的最佳方式是什么?以及将一个新的Brewer附加到啤酒集合中的最佳方式是什么

谢谢,
Justin

尝试先创建啤酒,然后创建啤酒商,并使用.append方法将啤酒商添加到啤酒中


不确定您是否将此视为一种选择-更好的方法可能是在Beers.Brewers字段中保留对(一部分)酿酒商ID的引用。在对数据进行编码时,可以将这些ID转换为完整字段值(使用自定义封送处理函数)。这可能是合适的,除非您考虑到速度/性能。

因此,我找到了解决上述问题的方法。要将新的
Brewer
添加到
Beer.Brewers
集合中,我需要执行以下操作:

brewerr := Brewer{}
    db.Where(&Brewer{FirstName: "justin"}).Find(&brewerr)

beerr := Beer{}
    db.Preload("Brewers").Where(&Beer{Name: "some lager"}).Find(&beerr).Association("Brewers").Append(&brewerr)

需要注意的是,我需要先
预加载
Beer.Brewers
集合,然后追加。未能预加载导致Append覆盖了该
啤酒的所有
啤酒商

以下想法 1.您可以独立创建酿酒厂 2.附加它们时,添加主键字段“BrewerId”,如图所示 3.这将在brewers表中查找Brewer并将其添加到啤酒中

导入(
“时间”
“github.com/jinju/gorm”
//戈姆使用
_“github.com/jinzhu/gorm/diagnols/postgres”
)
型啤酒结构{
BeerId uint`json:“id”`
名称字符串`json:“Name”gorm:“not null;”sql:“unique”`
描述字符串`json:“Description”gorm:“not null;”`
ImageURL字符串`json:“图像url”`
酒精含量浮动64`json:“酒精含量,默认值:0”`
特色bool`json:“特色”`
BrewStart time.time`json:“brew_开始”`
BrewEnd time.time`json:“brew_end”`
Brewers[]Brewer`json:“Brewers”gorm:“许多:啤酒酿造者;协会\外国密钥:啤酒酿造者id;外国密钥:啤酒id”`
}
类型布鲁尔结构{
BrewerId uint`json:“id”`
FirstName字符串`json:“first_name”`
LastName字符串`json:“姓氏”`
标题字符串`json:“标题”`
特色bool`json:“特色”`
}
func migrate(){
//Connection是连接字符串
连接:=“主机=%v端口=%v用户=%v数据库名=%v密码=%v sslmode=%v连接\u超时=%v”
db,u:=gorm.Open(“postgres”,连接)
db.AutoMigrate(&Beer{},&Brewer{})
db.Model(&Beer{}).Related(&Brewer{},“Brewers”)
db.Create(&Brewer{FirstName:“justin”})
db.Create&啤酒{
名字:“一些啤酒”,
描述:“描述一些淡啤酒”,
图像URL:“http://via.placeholder.com/350x150",
酒精含量:4.5,
特色:假,
布鲁斯特:实用时间(“2017年10月30日13:00(AEDT)”,
BrewEnd:utils.ParseTime(“2017年11月14日13:00(AEDT)”),
}).Association(“Brewers”).Append(&Brewer{BrewerId:123,})
}

您能看一下我的答案并评估它是否正确吗?看来我的答案和你在这里说的一模一样!
brewerr := Brewer{}
    db.Where(&Brewer{FirstName: "justin"}).Find(&brewerr)

beerr := Beer{}
    db.Preload("Brewers").Where(&Beer{Name: "some lager"}).Find(&beerr).Association("Brewers").Append(&brewerr)