前期工作:
先查看下要操作的两张表:
carton
data:image/s3,"s3://crabby-images/610d8/610d8d39c1f85fb25dcc58e79bd65bb5d271de2c" alt=""
carton_cate
data:image/s3,"s3://crabby-images/9af9e/9af9ecf2998bb0bff848d9b54db95dda317861d7" alt=""
//关系如下:
// 一个章节对应一个动漫(一对一;两种方法:belong to;has one)
// 一个动漫可以对应多个章节(一对多)
1、创建路由(cartonRoutes)
data:image/s3,"s3://crabby-images/bc23c/bc23cf65105c520023c69ec0df7725134707cfb5" alt=""
Go
package routers
import (
"gindemo04/controllers/admin"
"github.com/gin-gonic/gin"
)
func CartonController(r *gin.Engine) {
cartonRouters := r.Group("/carton")
{
cartonRouters.GET("/test", admin.CartonController{}.Test)
}
}
2、控制文件创建(cartonController.go)
Go
package admin
import (
"gindemo04/models"
"net/http"
"github.com/gin-gonic/gin"
)
type CartonController struct {
BaseController
}
func (con CartonController) Test(c *gin.Context) {
}
3、入口文件绑定(main.go)
data:image/s3,"s3://crabby-images/9cb40/9cb40ab3a9c332a19775450f53838b966876efd8" alt=""
4、固定要操作的表
data:image/s3,"s3://crabby-images/d25ea/d25ea92628ae9c1b34c52d70c5f268239a078ee9" alt=""
/models/carton:
Go
package models
//carton可以查询卡通章节,获取章节对应的分类要在cartoncate
type Carton struct { //这样默认操作的是cartons表
Id int
Title string
CartonCateId int //1、cartonCateId默认为外键(在建立关系后,默认以主表+id作为外键)
Status int
}
//固定要操作的表名
func (Carton) TableName() string {
return "carton"
}
data:image/s3,"s3://crabby-images/f10d7/f10d7533427e4ce2efa2415e2ab056b2eead32a4" alt=""
/models/carton_cate:
//foreignKey外键 如果是表名称加上Id默认也可以不配置,如果不是需要使用`gorm:"foreignKey:+你的外键名称配置
//references表示的是主键 默认就是Id 如果是Id的话可以不配置
Go
package models
//CartonCate查询分类,获取卡通分类下的章节
type CartonCate struct { //这样默认操作的是articles表
Id int //默认为主键
Title string
Status int
}
//固定要操作的表名
func (CartonCate) TableName() string {
return "carton_cate"
}
开始操作:
1、获取所有的动漫章节
cartonController.go:
Go
package admin
import (
"gindemo04/models"
"net/http"
"github.com/gin-gonic/gin"
)
type CartonController struct {
BaseController
}
//关系如下:
// 一个章节对应一个动漫(一对一;两种方法:belong to;has one)
// 一个动漫可以对应多个章节(一对多)
func (con CartonController) Test(c *gin.Context) {
//1、获取所有章节
cartonList := []models.Carton{}
models.DB.Find(&cartonList)
c.JSON(http.StatusOK, gin.H{
"List": cartonList,
})
}
data:image/s3,"s3://crabby-images/4584c/4584cd26a4e3d3995e102263f026bcae122774a4" alt=""
2、获取角色对应的动漫分类
/models/carton:
Go
package models
//carton可以查询卡通章节,获取章节对应的分类要在cartoncate
type Carton struct { //这样默认操作的是cartons表
Id int
Title string
CartonCateId int //1、cartonCateId默认为外键(在建立关系后,默认以主表+id作为外键)
Status int
CartonCate CartonCate
}
//固定要操作的表名
func (Carton) TableName() string {
return "carton"
}
cartonController.go:
Go
package admin
import (
"gindemo04/models"
"net/http"
"github.com/gin-gonic/gin"
)
type CartonController struct {
BaseController
}
//关系如下:
// 一个章节对应一个动漫(一对一;两种方法:belong to;has one)
// 一个动漫可以对应多个章节(一对多)
func (con CartonController) Test(c *gin.Context) {
//1、获取所有章节
// cartonList := []models.Carton{}
// models.DB.Find(&cartonList)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList,
// })
//2、获取角色对应的动漫分类
cartonList1 := []models.Carton{}
//preload是用来加载另外一张表的,这里的cartoncate是在carton.go内配置的
models.DB.Preload("CartonCate").Find(&cartonList1)
c.JSON(http.StatusOK, gin.H{
"List": cartonList1,
})
}
这里需要注意:你preload内的是需要和你在外部caton结构体是一致的,大小写,不然找不到
data:image/s3,"s3://crabby-images/33c9d/33c9d1a5788abad13025867e2d1515809174ec1b" alt=""
3、重写外键的操作
data:image/s3,"s3://crabby-images/3d6b7/3d6b7f331fab927d1c294b3b96a2fdcec42b75aa" alt=""
data:image/s3,"s3://crabby-images/eeab2/eeab28eef1faa2b28fbfe8ed832102684f049d07" alt=""
caton有默认的主键为ID,但是catoncate没有了对应的caton_cate_id做外键了(这里成为了cate_id),需要操作修改一下
/models/caton.go:
Go
package models
//carton可以查询卡通章节,获取章节对应的分类要在cartoncate
type Carton struct { //这样默认操作的是cartons表
Id int
Title string
CateId int //1、cartonCateId默认为外键(在建立关系后,默认以主表+id作为外键)
Status int
CartonCate CartonCate `gorm:"foreignKey:CateId;references:Id"`
// 2、没有1的情况下如何处理(重写外键)
}
//固定要操作的表名
func (Carton) TableName() string {
return "carton"
}
cartonController.go:
Go
package admin
import (
"gindemo04/models"
"net/http"
"github.com/gin-gonic/gin"
)
type CartonController struct {
BaseController
}
//关系如下:
// 一个章节对应一个动漫(一对一;两种方法:belong to;has one)
// 一个动漫可以对应多个章节(一对多)
func (con CartonController) Test(c *gin.Context) {
//1、获取所有章节
// cartonList := []models.Carton{}
// models.DB.Find(&cartonList)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList,
// })
//2、获取角色对应的动漫分类
cartonList1 := []models.Carton{}
//preload是用来加载另外一张表的,这里的cartoncate是在carton.go内配置的
models.DB.Preload("CartonCate").Find(&cartonList1)
c.JSON(http.StatusOK, gin.H{
"List": cartonList1,
})
}
data:image/s3,"s3://crabby-images/4dd0c/4dd0c86e5bbab7595400c64b7b403382953e49da" alt=""
4、依据动漫分类看其所属章节
4.1、先获取章节对应动漫的分类
cartonController.go:
Go
package admin
import (
"gindemo04/models"
"net/http"
"github.com/gin-gonic/gin"
)
type CartonController struct {
BaseController
}
//关系如下:
// 一个章节对应一个动漫(一对一;两种方法:belong to;has one)
// 一个动漫可以对应多个章节(一对多)
func (con CartonController) Test(c *gin.Context) {
//1、获取所有章节
// cartonList := []models.Carton{}
// models.DB.Find(&cartonList)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList,
// })
//2、获取角色对应的动漫分类
// cartonList1 := []models.Carton{}
// //preload是用来加载另外一张表的,这里的articlecate是在article.go内配置的
// models.DB.Preload("CartonCate").Find(&cartonList1)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList1,
// })
//4、依据分类看分类下文章
//4.1、先获取caton的分类
cartonList2 := []models.Carton{}
models.DB.Preload("CartonCate").Find(&cartonList2)
c.JSON(http.StatusOK, gin.H{
"List": cartonList2,
})
}
根据这里的cateid可以获取对应动漫
data:image/s3,"s3://crabby-images/a3dae/a3dae2a9542f46a51d4f194eba7bc7ed11465835" alt=""
4.2、依据分类看分类下章节
caton.go
Go
package models
//carton可以查询卡通章节,获取章节对应的分类要在cartoncate
type Carton struct { //这样默认操作的是cartons表
Id int
Title string
CateId int //1、cartonCateId默认为外键(在建立关系后,默认以主表+id作为外键)
Status int
CartonCate CartonCate `gorm:"foreignKey:CateId;references:Id"`
// 2、没有1的情况下如何处理(重写外键)
}
//固定要操作的表名
func (Carton) TableName() string {
return "carton"
}
catonCate.go
Go
package models
//CartonCate查询分类,获取卡通分类下的章节
//foreignKey外键 如果是表名称加上Id默认也可以不配置,如果不是需要使用`gorm:"foreignKey:+你的外键名称配置
//references表示的是主键 默认就是Id 如果是Id的话可以不配置
type CartonCate struct { //这样默认操作的是articles表
Id int //默认为主键 ()
Title string
Status int
Carton []Carton `gorm:"foreignKey:CateId;references:Id"`
}
//固定要操作的表名
func (CartonCate) TableName() string {
return "carton_cate"
}
cartonController.go:
Go
package admin
import (
"gindemo04/models"
"net/http"
"github.com/gin-gonic/gin"
)
type CartonController struct {
BaseController
}
//关系如下:
// 一个章节对应一个动漫(一对一;两种方法:belong to;has one)
// 一个动漫可以对应多个章节(一对多)
func (con CartonController) Test(c *gin.Context) {
//1、获取所有章节
// cartonList := []models.Carton{}
// models.DB.Find(&cartonList)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList,
// })
//2、获取角色对应的动漫分类
// cartonList1 := []models.Carton{}
// //preload是用来加载另外一张表的,这里的articlecate是在article.go内配置的
// models.DB.Preload("CartonCate").Find(&cartonList1)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList1,
// })
//4、依据分类看分类下文章
//4.1、先获取caton的分类
// cartonList2 := []models.Carton{}
// models.DB.Preload("CartonCate").Find(&cartonList2)
// c.JSON(http.StatusOK, gin.H{
// "List": cartonList2,
// })
//4.2、has many 一对多
cartonList3 := []models.CartonCate{}
models.DB.Preload("Carton").Find(&cartonList3)
c.JSON(http.StatusOK, gin.H{
"List": cartonList3,
})
}
data:image/s3,"s3://crabby-images/0432a/0432a605703e9277a0af2fb8852d70799995eda8" alt=""
//操作完成后看到一个空的cartoncate,去到carton.go将其注释掉
注释后的 carton.go
Go
package models
//carton可以查询卡通章节,获取章节对应的分类要在cartoncate
type Carton struct { //这样默认操作的是cartons表
Id int
Title string
CateId int //1、cartonCateId默认为外键(在建立关系后,默认以主表+id作为外键)
Status int
// CartonCate CartonCate `gorm:"foreignKey:CateId;references:Id"`
// 2、没有1的情况下如何处理(重写外键)
}
//固定要操作的表名
func (Carton) TableName() string {
return "carton"
}
再次查看:
data:image/s3,"s3://crabby-images/25ebf/25ebfa69a5b1a6456fc5f400e94d85b20f6a496a" alt=""