百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

beego ORM框架(beego框架怎么样)

ccwgpt 2024-09-17 12:27 43 浏览 0 评论

beego中内嵌了ORM框架, ORM框架可以将结构体和数据表进行对应起来, 只需要通过结构体和对象就可以对数据表进行操作。

设计类:模型类。

ORM另外一个作用:根据设计的类生成数据库中的表。

安装ORM

go get github.com/astaxie/beego/orm

执行的位置

D:\Go\study\src\class>go get github.com/astaxie/beego/orm

1 创建表

main.go

package main
import (
_ "class/models" /* 加载模型文件 */
_ "class/routers"
"github.com/astaxie/beego"
)
func main() {
beego.Run()
}

models/model.go

package models
import (
"github.com/astaxie/beego/orm"
_ "github.com/go-sql-driver/mysql"
)
type User struct {
Id int
Name string
Pwd string
}
func init() {
// 设置数据库基本信息
orm.RegisterDataBase("default", "mysql", "root:root@tcp(127.0.0.1:3307)/blog?charset=utf8")
/*
参数1 数据库的别名,用来在 ORM 中切换数据库使用
参数2 driverName
参数3 对应的链接字符串
*/
// 映射model数据
orm.RegisterModel(new(User)) //user表名
// 生成表
orm.RunSyncdb("default", false, true)
/*
default: 数据库别名 第二个参数 false:不需要更新表 true 需要更新表 第三个参数: 创建表的过程是否可见
*/
}

执行bee run命令

D:\Go\study\src\class>bee run
______
| ___ \
| |_/ / ___ ___
| ___ \ / _ \ / _ \
| |_/ /| __/| __/
\____/ \___| \___| v1.10.0
2018/12/09 22:40:47 INFO ? 0001 Using 'class' as 'appname'
2018/12/09 22:40:47 INFO ? 0002 Initializing watcher...
class
2018/12/09 22:40:54 SUCCESS ? 0003 Built Successfully!
2018/12/09 22:40:54 INFO ? 0004 Restarting 'class.exe'...
2018/12/09 22:40:54 SUCCESS ? 0005 './class.exe' is running...
create table `user`
-- --------------------------------------------------
-- Table Structure for `class/models.User`
-- --------------------------------------------------
CREATE TABLE IF NOT EXISTS `user` (
`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
`name` varchar(255) NOT NULL DEFAULT '' ,
`pwd` varchar(255) NOT NULL DEFAULT ''
) ENGINE=InnoDB;
2018/12/09 22:40:56.956 [I] [asm_amd64.s:1333] http server Running on http://:8080

2 ORM插入数据

controllers/default.go

package controllers
import (
    "class/models" /* 导入模型 */
    "github.com/astaxie/beego"
    "github.com/astaxie/beego/orm"
)
type MainController struct {
    beego.Controller
}
func (c *MainController) Get() {
    // 1. 有ORM对象
    o := orm.NewOrm()
    // 2. 有一个要插入数据的结构体对象
    user := models.User{}
    // 3. 对结构体赋值
    user.Name = "xuchenkai"
    user.Pwd = "123456"
    // 4. 插入
    _, err := o.Insert(&user)
    if err != nil {
        beego.Info("插入失败", err)
        return
    }
    c.Data["data"] = "今天中午吃饺子"
    c.TplName = "test.html"
}
func (c *MainController) Post() {
    c.Data["data"] = "今天中午吃面条"
    c.TplName = "test.html"
}

3 ORM查询

package controllers
import (
    "class/models"
    "github.com/astaxie/beego"
    "github.com/astaxie/beego/orm"
)
type MainController struct {
    beego.Controller
}
func (c *MainController) Get() {
    // 1. 有ORM对象
    o := orm.NewOrm()
    // 2. 查询对象
    user := models.User{}
    // 3. 指定查询对象字段值(字段值首字母要注意大写)
    //user.Id = 1
    user.Name = "xuchenkai"
    // 4. 查询
    //err := o.Read(&user) //根据id查询
    err := o.Read(&user, "Name") //根据Name查询, 必须传递第二个参数"Name"
    if err != nil {
    beego.Info("查询失败", err)
    }
    beego.Info("查询成功", user)
    c.Data["data"] = "今天中午吃饺子"
    c.TplName = "test.html"
  }
func (c *MainController) Post() {
    c.Data["data"] = "今天中午吃面条"
    c.TplName = "test.html"
}

4 ORM更新

package controllers
import (
"class/models"
"github.com/astaxie/beego"
"github.com/astaxie/beego/orm"
)
type MainController struct {
beego.Controller
}
func (c *MainController) Get() {
// 1. 有ORM对象
o := orm.NewOrm()
// 2. 需要更新的结构体对象
user := models.User{}
//3 查询需要更新的数据
user.Id = 1
err := o.Read(&user)
// 4 给数据赋值
if err == nil {
user.Name = "pengjihan"
user.Pwd = "123456789"
// 更新
_, err = o.Update(&user)
if err != nil {
beego.Info("更新失败", err)
return
}
}
c.Data["data"] = "今天中午吃饺子"
c.TplName = "test.html"
}
func (c *MainController) Post() {
c.Data["data"] = "今天中午吃面条"
c.TplName = "test.html"
}

ORM 删除

package controllers
import (
    "class/models"
    "github.com/astaxie/beego"
    "github.com/astaxie/beego/orm"
)
type MainController struct {
    beego.Controller
}
func (c *MainController) Get() {
    // 1. 有ORM对象
    o := orm.NewOrm()
    // 2. 删除的对象
    user := models.User{}
    // 3. 指定删除哪一条数据
    user.Id = 1
    // 4 删除
    _, err := o.Delete(&user)
    if err != nil {
        beego.Info("删除错误", err)
        return
    }
    c.Data["data"] = "今天中午吃饺子"
     c.TplName = "test.html"
}
func (c *MainController) Post() {
    c.Data["data"] = "今天中午吃面条"
    c.TplName = "test.html"
}
一对多查询
//用户结构体
type User struct {
    Id int
    Name string `orm:"unique"`
    Pwd string
    Articles []*Article `orm:"rel(m2m)"` //与Article建立多对多的关系, 建立中间表user_articles
}
/*
文章结构体 字段命名规则: 不要出现下划线(会出现两个下划线),
除了首字母大写外, 字段中出现第二个大写, 将会新建一个下划线
如: ArticleName => article_name
*/
type Article struct {
    Id int `orm:"pk;auto"`
    ArtiName string `orm:"size(20)"` //文章标题
    Atime time.Time `orm:"auto_now"` //内容
    Acount int `orm:"default(0);null"`
    Acontent string
    Aimg string
    ArticleType *ArticleType `orm:"rel(fk)"` //外键约束 与 ArticleType 建立一对多关系
    Users []*User `orm:"reverse(many)"` //与User立多对多的关系, 建立中间表user_articles
}
type ArticleType struct {
    Id int
    TypeName string `orm:"size(20)"`
    Articles []*Article `orm:"reverse(many)"` //与Article建立多对一的关系
}

一对多关系查询时必须使用RelatedSel(), 不然查不到数据, 参数要指定关联的表, 不然数据不正确

count, err = o.QueryTable("Article").RelatedSel("ArticleType").Count() //两个表建立了外键约束的关系

多对多插入

//多对多插入读者 插入到中间表
//1 获取操作对象
article := models.Article{Id: id}
//2 获取多对多操作对象
m2m := o.QueryM2M(&article, "Users") //article和user表建立了多对多的关系
//3 获取插入对象
userName := c.GetSession("userName") //获取登录的用户
user := models.User{}
user.Name = userName.(string)
o.Read(&user, "Name") //读取用户 写入到user结构体中 Name 查询的条件
//4 多对多插入
_, err = m2m.Add(&user)
if err != nil {
beego.Info("插入失败")
}

多对多查询

o.LoadRelated(&arti, "Users")

相关推荐

一个基于.Net Core遵循Clean Architecture原则开源架构

今天给大家推荐一个遵循CleanArchitecture原则开源架构。项目简介这是基于Asp.netCore6开发的,遵循CleanArchitecture原则,可以高效、快速地构建基于Ra...

AI写代码翻车无数次,我发现只要提前做好这3步,bug立减80%

写十万行全是bug之后终于找到方法了开发"提示词管理助手"新版本那会儿,我差点被bug整崩溃。刚开始两周,全靠AI改代码架构,结果十万行程序漏洞百出。本来以为AI说没问题就稳了,结果...

OneCode低代码平台的事件驱动设计:架构解析与实践

引言:低代码平台的事件驱动范式在现代软件开发中,事件驱动架构(EDA)已成为构建灵活、松耦合系统的核心范式。OneCode低代码平台通过创新性的注解驱动设计,将事件驱动理念深度融入平台架构,实现了业务...

国内大厂AI插件评测:根据UI图生成Vue前端代码

在IDEA中安装大厂的AI插件,打开ruoyi增强项目:yudao-ui-admin-vue31.CodeBuddy插件登录腾讯的CodeBuddy后,大模型选择deepseek-v3,输入提示语:...

AI+低代码技术揭秘(二):核心架构

本文档介绍了为VTJ低代码平台提供支持的基本架构组件,包括Engine编排层、Provider服务系统、数据模型和代码生成管道。有关UI组件库和widget系统的信息,请参阅UI...

GitDiagram用AI把代码库变成可视化架构图

这是一个名为gitdiagram的开源工具,可将GitHub仓库实时转换为交互式架构图,帮助开发者快速理解代码结构。核心功能一键可视化:替换GitHubURL中的"hub...

30天自制操作系统:第六天:代码架构整理与中断处理

1.拆开bootpack.c文件。根据设计模式将对应的功能封装成独立的文件。2.初始化pic:pic(可编程中断控制器):在设计上,cpu单独只能处理一个中断。而pic是将8个中断信号集合成一个中断...

AI写代码越帮越忙?2025年研究揭露惊人真相

近年来,AI工具如雨后春笋般涌现,许多人开始幻想程序员的未来就是“对着AI说几句话”,就能轻松写出完美的代码。然而,2025年的一项最新研究却颠覆了这一期待,揭示了一个令人意外的结果。研究邀请了16位...

一键理解开源项目:两个自动生成GitHub代码架构图与说明书工具

一、GitDiagram可以一键生成github代码仓库的架构图如果想要可视化github开源项目:https://github.com/luler/reflex_ai_fast,也可以直接把域名替换...

5分钟掌握 c# 网络通讯架构及代码示例

以下是C#网络通讯架构的核心要点及代码示例,按协议类型分类整理:一、TCP协议(可靠连接)1.同步通信//服务器端usingSystem.Net.Sockets;usingTcpListene...

从复杂到优雅:用建造者和责任链重塑代码架构

引用设计模式是软件开发中的重要工具,它为解决常见问题提供了标准化的解决方案,提高了代码的可维护性和可扩展性,提升了开发效率,促进了团队协作,提高了软件质量,并帮助开发者更好地适应需求变化。通过学习和应...

低代码开发当道,我还需要学习LangChain这些框架吗?| IT杂谈

专注LLM深度应用,关注我不迷路前两天有位兄弟问了个问题:当然我很能理解这位朋友的担忧:期望效率最大化,时间用在刀刃上,“不要重新发明轮子”嘛。铺天盖地的AI信息轰炸与概念炒作,很容易让人浮躁与迷茫。...

框架设计并不是简单粗暴地写代码,而是要先弄清逻辑

3.框架设计3.框架设计本节我们要开发一个UI框架,底层以白鹭引擎为例。框架设计的第一步并不是直接撸代码,而是先想清楚设计思想,抽象。一个一个的UI窗口是独立的吗?不是的,...

大佬用 Avalonia 框架开发的 C# 代码 IDE

AvalonStudioAvalonStudio是一个开源的跨平台的开发编辑器(IDE),AvalonStudio的目标是成为一个功能齐全,并且可以让开发者快速使用的IDE,提高开发的生产力。A...

轻量级框架Lagent 仅需20行代码即可构建自己的智能代理

站长之家(ChinaZ.com)8月30日消息:Lagent是一个专注于基于LLM模型的代理开发的轻量级框架。它的设计旨在简化和提高这种模型下代理的开发效率。LLM模型是一种强大的工具,可以...

取消回复欢迎 发表评论: