草庐IT

postgresql - 关联表中的 gorm many2many 和附加字段

我有一个many2many关联(它用于返回JSON)。它在模型中声明://models/school.gotypeSchoolstruct{IDint`gorm:"primary_key"`Namestring`gorm:"notnull"`Accreditations[]Accreditation`gorm:"many2many:school_accreditation;"`}效果很好。我在json中返回了关联。问题是我在school_accreditation表中有一个附加字段,但它未包含在响应中。我已经尝试像thisanswer中提议的那样为协会声明一个模型://models/s

postgresql - GORM 数据库中的自动迁移将不需要的字段添加到 SQL 表

当我在gorm数据库中创建表时,它向表中添加了我不需要的列。我不确定它是如何添加这些额外字段的。这导致我遇到一个错误,“pq:列“user_id”中的空值违反了非空约束”。“user_id”是添加的不需要的列。我正在使用gorm和postgreSQL。我的两个表之间存在多对多关系。我的第一个表已正确创建,第二个表stores是使用提供的字段加上两个不需要的字段创建的:“user_id”和“stores_id”。我尝试删除多对多关系以查看是否是问题所在,我尝试删除表并使用不同的字段重新创建它们。无论如何,我都无法摆脱这两个额外的列。第一个(工作)表:typeUserstruct{gorm

如果查询限制很大,goroutines 中的 GORM 会卡住

我决定构建创建CSV报告的服务。正在使用:Go1.12,GORM(作为PostgreSQLORM)funcmain(){...//initDBconnectionetcdeferdb.Close()gofetch(db)for{}//keepsopenprocess}funcfetch(db*gotm.DB){....//somecodecountspages,createsfileetcsqlLimit:=20000//setlimitfori:=0;i因此,当代码尝试获取数据时,它只会卡住。如果减少限制并设置100,例如,它运行SQL2次并卡住。Debug()也没有显示任何内容。正

sql - 如何限制gorm预加载的结果

typeItemstruct{TopicIdint`json:"topic_id"`Topic*Topic`json:"topic,omitempty"`BotIdint`json:"bot_id"`URLstring`gorm:"varchar(250);unique"json:"url"`Titlestring`gorm:"varchar(250)"json:"title"`}typeTopicstruct{Titlestring`gorm:"varchar(250)"json:"title"`Items[]*Item`json:"items,omitempty"`}这是两个模型。

postgresql - 如何在 gorm 中为 Association 请求主体属于并拥有一个

IhavePeopleandData,其中People有一个Dataand数据属于人如何在gogin中为该协会发出请求正文JSON?我在这种情况下使用gorm,对于这种情况,我不清楚gorm的文档,我应该像funcCreateTodo(db*gorm.DB)func(c*gin.Context){varpersonPersonvardataDatac.bindJSON(&Person)c.bindJSON(&Data)db.create(&Person)db.create(&Data)c.JSON(200,gin.H{result:[]interface{person,data})}t

reflection - 使用 gorm 库进行反射(reflect)

我在golang中使用gorm包(https://github.com/jinzhu/gorm)作为我的数据库库。我有很多类(数据库表),如“酒店”或“套餐”。复制代码不是好的编程习惯。作为一个愚蠢的例子-假设我想从每个表中获取第一个对象。我可以为每个对象编写此方法(GetFirstHotel、GetFirstPackage...)。但更好的方法是只有一个方法GetFirstItem,我会使用第一个参数创建与参数具有相同类的对象,然后将它传递给gorm,gorm将用数据库中的数据填充它,然后将其作为interface{}返回。我尝试为此使用反射,但失败了,因为我可能不太了解它。也许我只

去建立错误 "db.GetUsers undefined (type *gorm.DB has no field or method GetUsers)"

我是golang的新手,正在尝试使用gin+gorm制作API服务器。我尝试构建下面的代码,但出现了type*gorm.DBhasnofieldormethodGetUsers错误。这是一个非常简单的API服务器,我只想从users表中获取所有用户。packagemodelsimport("github.com/jinzhu/gorm"_"github.com/jinzhu/gorm/dialects/postgres")vardb*gorm.DBfuncinit(){varerrerrordb,err=gorm.Open("postgres","host=localhostdbnam

json - golang 使用 Gorm 查询数据库并在 http 响应中返回 json

我是Go的新手,正在使用Gorm查询我的postgres数据库,但我无法以字典格式返回我的数据,其中pokemon的类型用作该类型所有pokemon的数组的键json:cannotunmarshalobjectintoGovalueoftype[]models.Pokemon这是我的代码:typePokemonstruct{Namestring`db:"name"`Typestring`db:"type"`}pokemonTypes:=[6]string{"fire","electric","water","grass",}varretDatastruct{Poke[]Pokemon}

postgresql - Go GORM many2many问题

我想不出向模型添加关联的最佳方法。我有以下结构typeBeerstruct{IDuint`json:"id"`Namestring`json:"name"gorm:"notnull;"sql:"unique"`Descriptionstring`json:"description"gorm:"notnull;"`ImageURLstring`json:"image_url"`AlcoholContentfloat64`json:"alcohol_content,default:0"`Featuredbool`json:"featured"`BrewStarttime.Time`json

go - 在 Go 中引用 GORM 自动生成的字段

我正在编写我的第一个API,请耐心等待。我正在使用Go、Postgres和GORM以及我仍在使用的许多其他东西,但我遇到了GORM的AutoMigrate问题。最初我的用户结构是这样的:typeUserstruct{gorm.ModelEmailstring`gorm:"unique"json:"email"`Passwordstring`json:"password"`}当我运行db.AutoMigrate(&User{})时,它会在我的用户表中自动生成一个id字段(以及几个日期字段),这是我想要的。我挂断的是弄清楚如何在我的应用程序中引用这些字段。我修改了我的用户结构,现在看起来像