Day06:GORM快速入门02 增加| 青训营

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Day06:GORM快速入门02 增加| 青训营

导读

本套笔记是学习完Gin框架之后的下一个阶段,通过Gin框架我们可以很方便的和前端进行交互,下一步就是和数据库进行交互,这就需要使用GORM。本套笔记就是带你快速上手GORM,学习完这个之后就可以完成大项目的开发了,后续还会进行大项目的讲解开发,制作不易,喜欢的就点个关注吧。

本套课程基于GORM 指南 | GORM - The fantastic ORM library for Golang, aims to be developer friendly.进行讲解,是对这个的补充解释说明。

注意

代码详解大部分是注释的形式给出,请留意代码注释。

GORM介绍

GORM(Go Object Relational Mapping)是一个在 Go 语言中使用的优秀的 ORM(对象关系映射)库。它提供了简单且强大的 API,使开发人员能够轻松地与数据库进行交互

创建表

使用mysql建表,使用creat()

CREATE TABLE IF NOT EXISTS `users` (  
`id` INT(11) UNSIGNED AUTO_INCREMENT PRIMARY KEY,  
`name` VARCHAR(255) NOT NULL,  
`age` INT(11) NOT NULL,  
`birthday` DATETIME NOT NULL  
);

也可以使用

type User struct {  
ID uint  
Name string  
Age int  
Birthday time.Time  
}//表模型 
err = db.AutoMigrate(&User{})

成功创建

image.png

单个增加

package main  
import (  
"fmt"  
"gorm.io/driver/mysql"  
"gorm.io/gorm"  
"time"  
)  
type User struct {  
ID uint  
Name string  
Age int  
Birthday time.Time  
}//表模型 
func main() {  
db, _ := gorm.Open(mysql.New(mysql.Config{  
DSN: "root:Lycdemima1@@tcp(127.0.0.1:3306)/test?charset=utf8&parseTime=True&loc=Local", // DSN data source name  
DefaultStringSize: 256, // string 类型字段的默认长度  
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持  
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引  
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列  
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置  
}), &gorm.Config{})  
//以上为连接数据库,需要自己更改其中的相关配置,如root。  
user := User{Name: "Jinzhu", Age: 18, Birthday: time.Now()}//实例化模型  
result := db.Create(&user) // 通过数据的指针来创建  
fmt.Println(result)  
}

运行之后可以看到数据库里面出现了user

image.png

多个增加

package main  
import (  
"fmt"  
"gorm.io/driver/mysql"  
"gorm.io/gorm"  
"time"  
)  
type User struct {  
ID uint  
Name string  
Age int  
Birthday time.Time  
}//表的模型  
func main() {  
db, _ := gorm.Open(mysql.New(mysql.Config{  
DSN: "root:Lycdemima1@@tcp(127.0.0.1:3306)/test?charset=utf8&parseTime=True&loc=Local", // DSN data source name  
DefaultStringSize: 256, // string 类型字段的默认长度  
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持  
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引  
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列  
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置  
}), &gorm.Config{})
//以上为连接数据库,需要自己更改其中的相关配置,如root。
users := []User{  
User{Name: "xiaoming", Age: 18, Birthday: time.Now()},  
User{Name: "Jackson", Age: 19, Birthday: time.Now()},  
}  
result := db.Create(&users) // 创建表内容
fmt.Println(result)  
}

成功创建出数值

image.png

用指定的字段创造数据

可以确保只有这些特定的字段被插入到数据库中,而其他字段将被忽略。

package main  
import (  
"fmt"  
"gorm.io/driver/mysql"  
"gorm.io/gorm"  
"time"  
)  
type User struct {  
ID uint  
Name string  
Age int  
Birthday time.Time  
}  
func main() {  
db, _ := gorm.Open(mysql.New(mysql.Config{  
DSN: "root:Lycdemima1@@tcp(127.0.0.1:3306)/test?charset=utf8&parseTime=True&loc=Local", // DSN data source name  
DefaultStringSize: 256, // string 类型字段的默认长度  
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持  
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引  
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列  
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置  
}), &gorm.Config{})  
db.AutoMigrate(&User{})//创建表  
// 使用指定字段创建记录  
user := User{  
Name: "Jinzhu",  
Age: 18,  
}  
result := db.Select("Name", "Age").Create(&user)  
fmt.Println(result)  
}

运行之后数据库会是这样的结果

image.png

创建钩子

在使用 GORM 进行数据库操作时,你可以利用钩子(Hooks)来在执行数据库操作的不同阶段插入自定义逻辑。

func (user *User) BeforeCreate(tx *gorm.DB) error {
    // 在记录被创建之前执行逻辑
    // 可以在此处设置创建时间等字段的值
    return nil
}
func (user *User) AfterCreate(tx *gorm.DB) error {
    // 在记录被创建之后执行逻辑
    // 可以在此处执行其他相关操作
    return nil
}
func (user *User) BeforeUpdate(tx *gorm.DB) error {
    // 在记录被更新之前执行逻辑
    // 可以在此处更新修改时间等字段的值
    return nil
}
func (user *User) AfterUpdate(tx *gorm.DB) error {
    // 在记录被更新之后执行逻辑
    // 可以在此处执行其他相关操作
    return nil
}

goland示例

package main  
import (  
"fmt"  
"gorm.io/driver/mysql"  
"gorm.io/gorm"  
"time"  
)  
type User struct {  
ID uint  
Name string  
Age int  
Birthday time.Time  
}  
func (user *User) BeforeCreate(tx *gorm.DB) error {  
fmt.Println("钩子函数运行了")  
return nil  
}//我们定义的钩子函数  
func main() {  
db, _ := gorm.Open(mysql.New(mysql.Config{  
DSN: "root:Lycdemima1@@tcp(127.0.0.1:3306)/test?charset=utf8&parseTime=True&loc=Local", // DSN data source name  
DefaultStringSize: 256, // string 类型字段的默认长度  
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持  
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引  
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列  
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置  
}), &gorm.Config{})  
db.AutoMigrate(&User{})  
// 使用指定字段创建记录  
user := User{  
Name: "Jinzhu",  
Age: 18,  
}  
result := db.Select("Name", "Age").Create(&user)  
fmt.Println(result)  
}

运行之后,钩子函数先运行,之后才会创造记录

image.png

跳过钩子

如果你想在某些情况下跳过 GORM 钩子的执行,你可以使用 gorm.DB 对象的 SkipHooks 方法来实现

result := db.Session(&gorm.Session{SkipHooks: true}).Create(&user)

我们通过在 db.Session 调用中设置 SkipHooks 字段为 true,指示跳过所有钩子的执行。然后,我们调用 Create 方法来创建记录。

根据map创建记录

这个一般不常用,不过我们也需要了解一下

使用 GORM 批量插入记录可以通过传递 []map[string]interface{}[]Struct 来实现。

// 单个记录插入 
db.Model(&User{}).Create(map[string]interface{}{ "Name": "jinzhu", "Age": 18, }) 
// 批量插入 
db.Model(&User{}).Create([]map[string]interface{}{ {"Name": "jinzhu_1", "Age": 18}, {"Name": "jinzhu_2", "Age": 20}, })

默认值

使用gorm:"default:"标签来完成

type User struct {
  gorm.Model
  Name string
  Age  *int           `gorm:"default:18"`
  Active sql.NullBool `gorm:"default:true"
 }

这样如果我们不设置age和active,也会在记录里面分配值


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
鲁棒优化入门(二)——基于matlab+yalmip求解鲁棒优化问题
鲁棒优化的含义就是在最恶劣的情况下(不确定变量的取值使目标函数最大),求出满足约束条件,并且能使目标函数最优的决策变量。 yalmip工具箱可以用来求解鲁棒优化问题,但还是有一定局限性的,并不能处理任意形式的不确定集下的鲁棒优化问题,一般来说,当鲁棒优化问题的不确定集合为箱型不确定集、椭球不确定集以及多面体不确定集时,都可以用yalmip工具箱求解(具体细节可参考官方文档)。本文介绍了利用yalmip求鲁棒优化问题的一般方法。......
|
8月前
|
前端开发 JavaScript 开发工具
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
470 5
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
|
JavaScript 前端开发 机器人
Github 2024-06-17 开源项目周报 Top15
根据Github Trendings的统计,本周(2024年6月17日)共有15个项目上榜。按开发语言分类,Python项目最多,达6项;TypeScript和JavaScript各有3项;PHP、Blade、Lua、Dart及非开发语言项目各1项。这些项目涵盖从零构建技术、智能家居、高性能数据库到情感语音模型等多个领域,体现了开源社区的多样性和创新力。
427 0
|
11月前
Dreamweaver是怎么把图片转换成代码 简单五步骤即可解决
Dreamweaver是怎么把图片转换成代码的呢?其实利用Dreamweaver是可以将图片装换成代码的
557 5
|
SQL 安全 算法
网络安全与信息安全:构建数字世界的防线在数字化浪潮席卷全球的今天,网络安全与信息安全已成为维系社会秩序、保障个人隐私与企业机密的重要基石。本文旨在深入探讨网络安全漏洞的本质、加密技术的前沿进展以及提升安全意识的有效策略,为读者揭示数字时代下信息保护的核心要义。
本文聚焦网络安全与信息安全领域,详细剖析了网络安全漏洞的形成机理、常见类型及其潜在危害,强调了及时检测与修复的重要性。同时,文章系统介绍了对称加密、非对称加密及哈希算法等主流加密技术的原理、应用场景及优缺点,展现了加密技术在保障数据安全中的核心地位。此外,针对社会普遍存在的安全意识薄弱问题,提出了一系列切实可行的提升措施,如定期安全培训、强化密码管理、警惕钓鱼攻击等,旨在引导公众树立全面的网络安全观,共同构筑数字世界的安全防线。
|
SQL 人工智能 自然语言处理
2024年6月118篇代码大模型论文最全整理
基座模型与训练数据、代码微调、测试基准、代码Agent、低资源语言处理、AI代码安全与分析、人机交互、软件工程下游任务应用主题代码大模型论文分享,干货满满~
1306 2
|
索引 Windows
【qt】QTreeWidget 树形组件2
【qt】QTreeWidget 树形组件
174 0
|
机器学习/深度学习 编解码 移动开发
YOLOv8改进 | 2023 | FocusedLinearAttention实现有效涨点
YOLOv8改进 | 2023 | FocusedLinearAttention实现有效涨点
321 0
YOLOv8改进 | 2023 | FocusedLinearAttention实现有效涨点
|
安全 Java 大数据
一文搞懂什么是“注解”
一文搞懂什么是“注解”
581 0
一文搞懂什么是“注解”
|
移动开发 HTML5
WebSocket心跳机制
WebSocket心跳机制
267 0