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

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

ccwgpt 2024-09-17 12:27 30 浏览 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")

相关推荐

Spring WebFlux vs. Spring MVC(springboot是什么)

背景随着异步I/O和Netty等框架的流行,响应式编程逐渐走入大众的视野。但是,响应式编程本身并不是太新的概念,这个术语最早出现在1985年DavidHarel和AmirPnue...

深度解析微服务高并发:适配SpringMVC框架适配模块及实现原理

适配主流框架如果不借助Sentinel提供的适配主流框架的模块,则在使用Sentinel时需要借助try-catchfinally将要保护的资源(方法或代码块)包起来,在目标方法或代码块执行之前,调...

Spring MVC 底层原理深度解析:从请求到响应的全链路拆解

一、Servlet容器与DispatcherServlet的启动博弈1.Tomcat初始化阶段java//Tomcat初始化流程StandardContext#startInterna...

改造总结之传统SpringMVC架构转换为SpringBoot再到集群

改造出发点,是基于现在服务都在向上云的目标前进,传统SpringMVC难以满足项目持续构建、服务节点任意扩展的需求,所以开始了历史项目的改造。项目改造考虑的主要是兼容以前的业务代码,以及session...

SpringBoot3 整合 Spring MVC 全解析:开启高效 Web 开发之旅

在当今的JavaWeb开发领域,Spring框架家族无疑占据着重要的地位。其中,SpringBoot3和SpringMVC更是开发者们构建强大、高效Web应用的得力工具。今天,...

一文读懂SpringMVC(一文读懂!残疾人低保边缘家庭能领的超实用福利政策)

1.SpringMVC定义1.1.MVC定义Model(模型):是应用程序中用于处理应用程序数据逻辑的部分。通常模型对象负责在数据库中存取数据View(视图):是应用程序中处理数据显示的部分。通常...

69 个Spring mvc 全部注解:真实业务使用案例说明(必须收藏)

SpringMVC框架的注解为Web开发提供了一种简洁而强大的声明式方法。从控制器的定义、请求映射、参数绑定到异常处理和响应构建,这些注解涵盖了Web应用程序开发的各个方面。它们不仅简化了编码工作,...

Spring MVC工作原理:像拼积木一样构建Web应用

SpringMVC工作原理:像拼积木一样构建Web应用在Java的Web开发领域,SpringMVC无疑是一个让人又爱又恨的存在。它像一位神通广大的积木搭建大师,将一个个分散的功能模块巧妙地拼接在...

5千字的SpringMVC总结,我觉得你会需要

思维导图文章已收录到我的Github精选,欢迎Star:https://github.com/yehongzhi/learningSummary概述SpringMVC再熟悉不过的框架了,因为现在最火的...

SpringMVC工作原理与优化指南(springmvc工作原理和工作流程)

SpringMVC工作原理与优化指南在现代Java开发中,SpringMVC无疑是构建Web应用程序的首选框架之一。它以其优雅的设计和强大的功能吸引了无数开发者。那么,SpringMVC究竟是如何工作...

Spring MVC框架源码深度剖析:从入门到精通

SpringMVC框架源码深度剖析:从入门到精通SpringMVC框架简介SpringMVC作为Spring框架的一部分,为构建Web应用程序提供了强大且灵活的支持。它遵循MVC(Model-V...

3000字搞明白SpringMVC工作流程、DispatcherServlet类、拦截器!

SpringMVC基础虽然SpringBoot近几年发展迅猛,但是SpringMVC在Web开发领域仍然占有重要的地位。本章主要讲解SpringMVC的核心:DispatcherServlet类...

多年经验大佬用2000字透彻解析SpringMVC的常用注解及相关示例

SpringMVC注解SpringMVC框架提供了大量的注解,如请求注解、参数注解、响应注解及跨域注解等。这些注解提供了解决HTTP请求的方案。本节主要讲解SpringMVC的常用注解及相关示例...

知乎热议:如何成为前端架构师,赚百万年薪?

作者|慕课网精英讲师双越最近有一条知乎热议:从一个前端工程师,如何根据目标,制定计划,才能快速进阶成为前端架构师?不久之前我参与了一次直播,讲到了自己对于Web前端架构师的理解。架构师这个角色...

学习笔记-前端开发架构设计(前端架构设计方案)

前端开发的技术选项主要包含以下几点,下面对一些名词概念的解释做了笔记:1、分层架构:把功能相似,抽象级别相近的实现进行分层隔离优势:松散耦合(易维护,易复用,易扩展)常见分层方式:MVC,MVVM2、...

取消回复欢迎 发表评论: