https://blog.csdn.net/f95_sljz/article/details/103687308
gorm的文档对于我来讲比较难看懂,因为一直使用beego嘛。
文档对于返回值没有说,要加.Error才是返回错误
这个jion是非常好用的,如果不用jion,就要将查出来的结果,循环,赋给新的结构体,写法很不优雅。
而xorm的这种操作不需要select字段。
如下是xorm的jion:
type OnlyOfficeAttach struct {
OnlyOffice `xorm:"extends"`
OnlyAttachment `xorm:"extends"`
User `xorm:"extends"`
}
//分页取得所有项目
func GetDocList(offset, limit int) (docs []*OnlyOfficeAttach, err error) {
engine.Table("OnlyOffice").Join("INNER", "user", "user.id = onlyoffice.uid").
Join("INNER", "OnlyAttachment", "OnlyAttachment.id = onlyoffice.id").Limit(limit, offset).
Find(&docs)
return docs, err
}
如下是gorm的jion: 而且下列代码中,product表还可以再查project表,project表已经和最开始的cart表没有关系了。也就是表A——表B——表C,表A和表C没有关系,通过表B可以查表C。这种关联很厉害。
gorm必须使用select将要查的字段映射,否则返回不了值。
而且,这种关联,不需要什么外键啊,关联啊啥的,奇怪。jion和关联是什么关系?
//购物车表
type UserCart struct {
Id int64 `json:"id"`
UserId int64 `json:"userid"`
Status int `json:"status"`
UserNickname string `json:"usernickname"`
ProductTitle string `json:"producttitle"`
ProjectTitle string `json:"projecttitle"`
TopProjectTitle string `json:"topprojecttitle"`
}
//查询某个用户借阅记录
func GetUserCart(uid int64, limit, offset, status int) (usercarts []UserCart, err error) {
//获取DB
db := GetDB()
// 必须要写权select,坑爹啊
err = db.Table("cart").Select("cart.id,cart.user_id,cart.status,user.nickname as user_nickname, product.title as product_title, project.title as project_title, topproject.title as topproject_title").Where("user_id=?", uid).
Joins("left JOIN user on user.id = cart.user_id").
Joins("left join product on product.id = cart.product_id").
Joins("left join project on project.id = product.project_id").
Joins("left join project on project.id = product.top_project_id").
Limit(limit).Offset(offset).Scan(&usercarts).Error
return usercarts, err
}