当前位置: 首页 > news >正文

Go 语言常见的 ORM 框架

ORM(Object-Relational Mapping)是一种编程技术,用于将面向对象编程语言中的对象模型和关系数据库中的数据模型相互映射。ORM框架可以把数据操作从 SQL 语句中抽离出来,将关系型数据库中的表映射成对象,通过面向对象的方式操作数据库,提高了开发效率和代码可读性。ORM框架通常会提供持久化(Persistence)、查询数据(Query)和关系映射(Relationship Mapping)等核心功能。使用ORM,开发者可以更加专注于业务逻辑的实现,无需过多关注底层数据操作细节。常用的ORM框架有Hibernate、MyBatis、Entity Framework、Django ORM等。

Gorm

  • 下载:go get -u github.com/jinzhu/gorm

连接库

package mainimport "github.com/jinzhu/gorm"func main() {db, err := gorm.Open("mysql", "root:password@(127.0.0.1:3306)/db1?"+"charset=utf8mb4&parseTime=True&loc=Local")if err != nil {panic(err)}defer db.Close()db.DB().SetMaxIdleConns(10)db.DB().SetMaxOpenConns(100)
}

创建表

CREATE TABLE `gorm_users`(
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`phone` varchar(255) DEFAULT NULL,
`name` varchar(255) DEFAULT NULL,
`password` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
)ENGINE = InnoDB AUTO_INCREMENT = 39 DEFAULT CHARSET = utf8

定义结构体

type GormUser struct {ID uint `json:"id"`Phone string `json:"phone"`Name string `json:"name"`Password string `json:"password"`
}

插入数据

import ("github.com/jinzhu/gorm""crypto/md5""encoding/hex"
)func insert(db *gorm.DB) {GormUser := GormUser{Phone: "1888888888",Name: "Shirdon",Password: md5Password("666666"),}db.Save(&GormUser)//db.Create(&GormUser)
}
func md5Password(password string) string {hasher := md5.New()hasher.Write([]byte(password))return hex.EncodeToString(hasher.Sum(nil))
}

删除数据

func delete(db *gorm.DB) {var GormUser = new(GormUser)db.Where("phone = ?","1388888888").Delete(&GormUser)
}

查询数据

func selectDb(db *gorm.DB) {var GormUser = new(GormUser)db.Where("phone = ?","1888888888").Find(&GormUser)//db.First(&GormUser,"phone=?","1888888888")fmt.Println(GormUser)
}

更新数据

func update(db *gorm.DB) {var GormUser = new(GormUser)db.Model(&GormUser).Where("phone = ?","1888888888").Update("phone","1388888888")
}

错误处理

func update(db *gorm.DB) {var GormUser = new(GormUser)err := db.Model(&GormUser).Where("phone = ?","1888888888").Update("phone","1388888888").Errorif err != nil {//...}
}

事务处理

func transc(db *gorm.DB) {tx := db.Begin()GormUser := GormUser{Phone: "18888888888",Name: "Shirdon",Password: md5Password("666666"),}if err := tx.Create(&GormUser).Error;err!=nil {tx.Rollback()fmt.Println(err)}db.First(&GormUser,"phone =?","18888888888")tx.Commit()
}

日志处理

	db.LogMode(true)db.SetLogger(log.New(os.Stdout,"\r\n",0))

Beego

安装

  • go get github.com/astaxie/beego/orm
  • go get github.com/go-sql-driver/mysql

连接数据库

	maxIdle := 30maxConn := 30orm.RegisterDataBase("default","mysql","root:root@/orm_test?charset=utf8",maxIdle,maxConn)//orm.SetMaxIdleConns("default",30)//orm.SetMaxOpenConns("default",30)

注册模型

func init() {orm.RegisterModel(new(BeegoUser))//orm.RegisterModel(new(BeegoUser),new(Profile),new(Post))//orm.RegisterModel("prefix",new(BeegoUser))
}

定义表

CREATE TABLE `beego_user`(
`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增 ID',
`name` varchar(20) DEFAULT '' COMMENT '名字',
`phone` varchar(20) DEFAULT '' COMMENT '电话',
PRIMARY KEY(`id`)
)ENGINE = InnoDB DEFAULT CHARSET=utf8

定义结构体

type BeegoUser struct {Id intName stringPhone string
}

package mainimport ("fmt""github.com/astaxie/beego/orm"_ "github.com/go-sql-driver/mysql"
)type BeegoUser struct {Id    intName  stringPhone string
}func main() {o := orm.NewOrm()user := new(BeegoUser)user.Name = "Shirdon"user.Phone = "18888888888"fmt.Println(o.Insert(user))
}

func delete() {o := orm.NewOrm()user:= BeegoUser{}user.Id=7if num , err := o.Delete(&user);err!=nil{fmt.Println("删除失败")	} else {fmt.Println("删除数据影响的行数:",num)}
}

func selectDb() {o := orm.NewOrm()user := BeegoUser{} // 根据条件查询记录user.Id = 6err := o.Read(&user)if err == orm.ErrNoRows {fmt.Println("记录不存在")} else if err == orm.ErrMissPK {fmt.Println("缺少主键")} else if err != nil {fmt.Println(err)} else {fmt.Println(user)}
}

func update() {o := orm.NewOrm()user := BeegoUser{} // 根据条件查询记录user.Id=6user.Name="James"num, err := o.Update(&user)if err != nil {fmt.Println("更新失败")} else {fmt.Println("更新影响的行数:",num)}
}

原生查询

func rowQueryDb() {o := orm.NewOrm()var r orm.RawSeterr = o.Raw("UPDATE user SET name =? WHERE name =?", "James","jim")
}

事务

func transc() {o := orm.NewOrm()o.Begin() // 开启事务user1 := BeegoUser{}user1.Id = 6user1.Name = "James"user2 := BeegoUser{}user2.Id =12user2.Name = "Wade"_,err1 := o.Update(&user1)_,err2 := o.Insert(&user2)if err1 !=nil || err2 != nil{o.Rollback()}else {o.Commit()}}

调试模式下打印

	orm.Debug = truevar w io.Writerorm.DebugLog = orm.NewLog(w)
http://www.lryc.cn/news/210084.html

相关文章:

  • 【错误解决方案】ModuleNotFoundError: No module named ‘cPickle‘
  • NodeJS14.18.0 安装,以及安装相应版本node-sass
  • cosover是什么?crossover23又是什么软件
  • AR眼镜安卓主板,智能眼镜光机方案定制
  • Qt中实现页面切换的两种方式
  • 公司电脑如何限制安装软件
  • 【C++】STL容器——list类的使用指南(含代码演示)(13)
  • Table-GPT:让大语言模型理解表格数据
  • 基于单片机的温湿度和二氧化碳检测系统设计
  • leetcode做题笔记204. 计数质数
  • MySQL Server 5.5 软件和安装配置教程
  • 【23种设计模式】依赖倒置原则
  • C++ 结构简介
  • element的tabs组件使用问题解决
  • python实验1 猜数字游戏
  • docker 中给命令起别名
  • PHP的yaf框架自带插件
  • SpringCloud Alibaba【三】Gateway
  • Azure - 机器学习实战:快速训练、部署模型
  • C语言十进制转其它进制
  • 网络建设 之 React数据管理
  • 如何隐藏woocommerce 后台header,woocommerce-layout__header
  • 通俗易懂的理解 解耦 概念
  • 全志A40i android7.1 增加Vlan功能
  • NAT技术与代理服务器
  • 关于报错java.util.ConcurrentModificationException: null的源码分析和解决
  • 使用koa搭建服务器(一)
  • echarts的柱状图的重叠和堆叠实现两个柱体的显示和之前的差值显示
  • 泛积木-低代码 使用攻略
  • 红队专题-从零开始VC++C/S远程控制软件RAT-MFC-远控介绍及界面编写