beego中orm关联查询使用解析

这两天在学习beego框架,之前学习的时候遗漏了很多东西,比如orm、缓存、应用监控、模板处理等,这里将通过实例记录下如何使用beego自带的orm进行关联查询操作。

首先说明下,beego的orm有自动建表的功能,使用方法呢如下:

// 数据库别名
name := "default"

// drop table 后再建表
force := true

// 打印执行过程
verbose := true

// 遇到错误立即返回
err := orm.RunSyncdb(name, force, verbose)
if err != nil {
    fmt.Println(err)
}

不过我们这里不使用自动建表,而是使用pd设计好之后生成对应的sql文件,先看下数据库表关系设置:

主要关系是:

会员(用户) -> 文章:一对多

文章 -> 文章分类:多对一

文章 -> 评论:一对多

说明:beego的orm使用时,外键id在关联查询时会默认添加一个"_id"结尾,比如:文章表对应的作者id,orm在关联查询时会默认查询xxx_id,其中xxx为struct中定义的json字段全称,这样的话最好定义外键id时直接写成xxx_id形式,然后struct的字段的json tag写成xxx即可。

struct定义

type User struct {
    Id        int        `json:"id"`
    Name      string     `json:"name"`
    Nickname  string     `json:"nickname"`
    Mobile    string     `json:"mobile"`
    Age       int        `json:"age"`
    Sex       bool       `json:"sex"`
    Email     string     `json:"email"`
    Address   string     `json:"address"`
    Pass      string     `json:"pass"`
    Addtime   int        `json:"addtime"`
    Lastlogin int        `json:"lastlogin"`
    Articles  []*Article `orm:"reverse(many)"`
}

type Article struct {
    Id       int          `json:"id"`
    Title    string       `json:"title"`
    Content  string       `json:"content"`
    Addtime  int          `json:"addtime"`
    Uptime   int          `json:"uptime"`
    User     *User        `json:"user" orm:"rel(fk)"`
    Link     string       `json:"link"`
    Intro    string       `json:"intro"`
    Type     *Articletype `json:"type" orm:"rel(fk)"`
    Comments []*Comment   `orm:"reverse(many)"` //反向一对多关联
}

type Articletype struct {
    Id       int        `json:"id"`
    Name     string     `json:"name"`
    Orderno  int        `json:"orderno"`
    Articles []*Article `orm:"reverse(many)"`
}

type Comment struct {
    Id      int      `json:"id"`
    Cname   string   `json:"cname"`
    Cemail  string   `json:"cemail"`
    Content string   `json:"content"`
    Addtime int      `json:"addtime"`
    Aid     *Article `json:"article" orm:"rel(fk)"`
}

数据库数据如下:

文章表数据

文章分类表数据

会员表

关联查询

首先是一对多关联查询:

1、首先是根据用户查询所有文章

var articles []*models.Article
    orm.NewOrm().QueryTable("article").Filter("User", 1).RelatedSel().All(&articles)
    for _, v := range articles {
        fmt.Println(v.Id)
    }

测试如下,打印的sql及结果:

2、根据文章查询对应用户

var user models.User
    err := orm.NewOrm().QueryTable("user").Filter("Name", "张三").Limit(1).One(&user)
    if err == nil {
        fmt.Println(user)
    }

测试如下:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Golang语言社区

Golang拦截器的一种实现

前言 说起拦截器,大家一定会想起Java语言。 Java里的拦截器是动态拦截Action调用的对象,它提供了一种机制使开发者可以定义在一个action执行的前后...

41711
来自专栏java思维导图

mybatis-plus思维导图,让mybatis-plus不再难懂

1 mybatis-plus与mybatis mybatis Mybatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis...

3248
来自专栏Golang语言社区

Go语言的网络编程简介

本文通过 Go 语言写几个简单的通信示例,从 TCP 服务器过渡到 HTTP 开发,从而简单介绍 net 包的运用。 TCP 服务器 首先来看一个 TCP 服务...

34815
来自专栏xingoo, 一个梦想做发明家的程序员

Java程序员的日常 —— 工作一天的收获

看题目可能是扯皮,其实还是有很多专业知识的。从最开始没有注意到设计原则,到后面的jquery实战技巧,都是今天一天碰到的问题。 每天整理一点点,每天收获一点...

1977
来自专栏用户2442861的专栏

详解HttpURLConnection

http://blog.csdn.net/woxueliuyun/article/details/43267365

351
来自专栏Golang语言社区

Go语言的网络编程简介

本文通过 Go 语言写几个简单的通信示例,从 TCP 服务器过渡到 HTTP 开发,从而简单介绍 net 包的运用。 TCP 服务器 首先来看一个 TCP 服务...

3807
来自专栏Java开发者杂谈

分布式改造剧集之Redis缓存踩坑记

1564
来自专栏林德熙的博客

WPF 使用RPC调用其他进程

如果在 WPF 需要用多进程通信,一个推荐的方法是 WCF ,因为 WCF 是 RPC 计算。先来讲下 RPC (Remote Procedure Call) ...

511
来自专栏Java3y

Activiti就是这么简单

Activiti介绍 什么是Activiti? Activiti5是由Alfresco软件在2010年5月17日发布的业务流程管理(BPM)框架,它是覆盖了业务...

4398
来自专栏前端架构与工程

NativeScript工作原理

NativeScript是一个runtime,它提供一些机制可以使用JavaScript构建原生的IOS、Android甚至WP(未来会加入)应用。Native...

2546

扫码关注云+社区