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、...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Spring WebFlux vs. Spring MVC(springboot是什么)
- 深度解析微服务高并发:适配SpringMVC框架适配模块及实现原理
- Spring MVC 底层原理深度解析:从请求到响应的全链路拆解
- 改造总结之传统SpringMVC架构转换为SpringBoot再到集群
- SpringBoot3 整合 Spring MVC 全解析:开启高效 Web 开发之旅
- 一文读懂SpringMVC(一文读懂!残疾人低保边缘家庭能领的超实用福利政策)
- 69 个Spring mvc 全部注解:真实业务使用案例说明(必须收藏)
- Spring MVC工作原理:像拼积木一样构建Web应用
- 5千字的SpringMVC总结,我觉得你会需要
- SpringMVC工作原理与优化指南(springmvc工作原理和工作流程)
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- bootstrap框架 (43)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- express框架 (43)
- springmvc框架 (49)
- scrapy框架 (52)
- beego框架 (42)
- java框架spring (43)
- grpc框架 (55)
- orm框架有哪些 (43)
- ppt框架 (48)
- 内联框架 (52)
- winform框架 (46)
- gui框架 (44)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)