go语言Gin框架的学习路线(十一)

目录

GORM的CRUD教程

更新操作

更新所有字段

更新指定字段

使用 Select 和 Omit 更新

无 Hooks 更新

批量更新

删除操作

删除记录

批量删除

软删除

物理删除

示例代码

GORM的CRUD教程

CRUD 是 "Create, Read, Update, Delete"(创建、查询、更新、删除)的缩写,代表了数据库操作的基本功能。在 GORM 的上下文中,CRUD 指的是使用 GORM 库来执行这些基本的数据库操作。

更新操作

更新所有字段

使用 Save 方法可以更新对象的所有字段。

type User struct {gorm.ModelName stringAge  int
}func main() {db, err := gorm.Open(/* 连接数据库的参数 */)if err != nil {log.Fatal(err)}// 假设已经从数据库中获取了用户数据var user Userdb.First(&user, "id = ?", 1)// 更新用户信息user.Name = "Bob"user.Age = 25// 保存更新db.Save(&user)
}

这段代码是使用Go语言和GORM库来操作数据库的示例。GORM是一个用于Golang的开源对象关系映射(ORM)库,它简化了与数据库的交互。

首先,定义了一个名为User的结构体,它包含了三个字段:gorm.ModelNameAgegorm.Model是GORM提供的一个基础模型,包含了一些通用的字段,如创建时间、更新时间和删除时间等。

接下来,在main函数中,首先尝试连接到数据库。这里省略了具体的连接参数,通常包括数据库类型、用户名、密码、主机地址和端口等信息。如果连接失败,程序将记录错误并退出。

然后,假设已经从数据库中获取了一个用户数据,将其存储在名为user的变量中。这里使用了db.First方法,它会根据给定的条件(这里是id = 1)查询数据库中的第一条记录,并将其赋值给user变量。

接下来,对user变量的属性进行了修改,将其Name属性设置为"Bob",Age属性设置为25。

最后,使用db.Save方法将更新后的user对象保存回数据库。这将触发数据库的更新操作,将对应记录的NameAge字段更新为新的值。

更新指定字段

使用 UpdateUpdates 方法可以更新指定字段。

// 更新单个字段
db.Model(&user).Update("age", 26)// 更新多个字段
db.Model(&user).Updates(User{Name: "Alice", Age: 30})
  1. db.Model(&user).Update("age", 26):这行代码表示更新名为user的对象的年龄字段为26。db.Model(&user)表示将要操作的对象设置为userUpdate("age", 26)表示将age字段的值更新为26。

  2. db.Model(&user).Updates(User{Name: "Alice", Age: 30}):这行代码表示更新名为user的对象的多个字段。db.Model(&user)表示将要操作的对象设置为userUpdates(User{Name: "Alice", Age: 30})表示将user对象的Name字段更新为"Alice",并将Age字段更新为30。

使用 Select 和 Omit 更新

使用 SelectOmit 可以控制更新哪些字段。

// 更新指定字段,忽略其他字段
db.Model(&user).Select("age").Omit("name").Update("age", 27)
  1. db.Model(&user):表示将要操作的对象设置为user
  2. Select("age"):表示只选择要更新的字段为age
  3. Omit("name"):表示忽略name字段,即不对该字段进行任何操作。
  4. Update("age", 27):表示将age字段的值更新为27。

综合起来,这段代码的作用是将名为user的对象的年龄字段更新为27,但不会更改其名字段的任何值。

无 Hooks 更新

使用 UpdateColumnUpdateColumns 方法可以进行无 Hooks 更新。

// 更新单个字段,不触发 Hooks
db.Model(&user).UpdateColumn("age", 28)// 更新多个字段,不触发 Hooks
db.Model(&user).UpdateColumns(User{Age: 29})

这段代码是使用Go语言的GORM库来更新数据库中的记录,同时避免触发相关的钩子(Hooks)。

  1. db.Model(&user).UpdateColumn("age", 28):这行代码表示更新名为user的对象的年龄字段为28。db.Model(&user)表示将要操作的对象设置为userUpdateColumn("age", 28)表示将age字段的值更新为28。与普通的Update方法不同,UpdateColumn不会触发任何关联的钩子函数。

  2. db.Model(&user).UpdateColumns(User{Age: 29}):这行代码表示更新名为user的对象的多个字段。db.Model(&user)表示将要操作的对象设置为userUpdateColumns(User{Age: 29})表示将user对象的Age字段更新为29。同样地,与普通的Updates方法不同,UpdateColumns不会触发任何关联的钩子函数。

通过使用UpdateColumnUpdateColumns方法,可以确保在更新数据时不会触发任何额外的钩子函数,这对于某些情况下需要更精确控制更新过程的场景非常有用。

 

批量更新

使用 SQL 表达式进行批量更新。

db.Table("users").Where("age > ?", 20).Update("age", gorm.Expr("age + 1"))

这段代码是使用Go语言的GORM库来更新数据库中的记录。

  1. db.Table("users"):表示将要操作的数据表为"users"。
  2. Where("age > ?", 20):表示筛选条件,只选择年龄大于20的用户。
  3. Update("age", gorm.Expr("age + 1")):表示将满足条件的用户的age字段的值加1。gorm.Expr用于构建表达式,这里使用了SQL表达式age + 1来实现自增操作。

综合起来,这段代码的作用是将名为"users"的数据表中年龄大于20的所有用户的年龄字段值加1。

删除操作

删除记录

使用 Delete 方法删除记录时,需要确保主键字段有值。

// 删除单个记录
db.Delete(&user, "id = ?", 1)// 删除多个记录
db.Delete(&User{}, "age > ?", 20)

这段代码是使用Go语言的GORM库来删除数据库中的记录。

  1. db.Delete(&user, "id = ?", 1):这行代码表示删除名为user的对象中,满足条件"id = 1"的记录。&user表示要操作的对象,"id = ?"是SQL语句的条件部分,1是条件的值。

  2. db.Delete(&User{}, "age > ?", 20):这行代码表示删除所有年龄大于20的用户记录。&User{}表示要操作的对象,这里使用了空结构体作为占位符,因为只需要指定表名和条件即可。"age > ?"是SQL语句的条件部分,20是条件的值。

 

批量删除

使用 Delete 方法可以删除多个记录。

db.Delete(&User{}, "age > ?", 20)

db.Delete(&User{}, "age > ?", 20):这行代码表示删除所有年龄大于20的用户记录。&User{}表示要操作的对象,这里使用了空结构体作为占位符,因为只需要指定表名和条件即可。"age > ?"是SQL语句的条件部分,20是条件的值。 

软删除

如果模型包含 DeletedAt 字段,GORM 会自动处理软删除。

// 软删除
db.Delete(&user, "id = ?", 1)// 查询未被软删除的记录
var users []User
db.Find(&users, "deleted_at IS NULL")

这段代码是使用Go语言的GORM库来操作数据库中的记录。

  1. db.Delete(&user, "id = ?", 1):这行代码表示删除ID为1的用户记录。&user表示要操作的对象,"id = ?"是SQL语句的条件部分,1是条件的值。这里的软删除是指将用户的deleted_at字段设置为当前时间,而不是直接从数据库中删除记录。

  2. var users []User:这行代码声明了一个名为users的切片,用于存储查询到的用户记录。

  3. db.Find(&users, "deleted_at IS NULL"):这行代码表示查询所有未被软删除的用户记录。&users表示要将查询结果存储到哪个变量中,"deleted_at IS NULL"是SQL语句的条件部分,表示只查询deleted_at字段为NULL(即未被软删除)的记录。

物理删除

如果需要进行物理删除,可以使用 Unscoped 方法。

// 物理删除
db.Unscoped().Delete(&user, "id = ?", 1)
  1. db.Unscoped():这个方法用于禁用软删除功能,使得后续的删除操作会直接从数据库中删除记录,而不是更新deleted_at字段。

  2. Delete(&user, "id = ?", 1):这行代码表示删除ID为1的用户记录。&user表示要操作的对象,"id = ?"是SQL语句的条件部分,1是条件的值。这里的物理删除是指直接从数据库中删除记录,而不是将其标记为已删除。

 

示例代码

以下是完整的示例代码,演示如何在 GORM 中实现 CRUD 操作中的 "Update" 和 "Delete" 功能。

package mainimport ("gorm.io/driver/sqlite""gorm.io/gorm""gorm.io/gorm/logger""log"
)type User struct {gorm.ModelName stringAge  int
}func main() {// 连接数据库db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{Logger: logger.Default.LogMode(logger.Info),})if err != nil {log.Fatal(err)}// 自动迁移模式db.AutoMigrate(&User{})// 创建记录user := User{Name: "Alice", Age: 30}db.Create(&user)// 更新记录user.Age = 31db.Save(&user)// 更新指定字段db.Model(&user).Update("age", 32)// 使用 Select 和 Omit 更新db.Model(&user).Select("age").Omit("name").Update("age", 33)// 无 Hooks 更新db.Model(&user).UpdateColumn("age", 34)// 批量更新db.Table("users").Where("age > ?", 20).Update("age", gorm.Expr("age + 1"))// 删除记录db.Delete(&user, "id = ?", user.ID)// 软删除db.Delete(&user, "id = ?", user.ID)// 物理删除db.Unscoped().Delete(&user, "id = ?", user.ID)
}

在这个示例中,我们首先连接到 SQLite 数据库,然后定义了一个 User 结构体,并进行了自动迁移。接着,我们创建、更新和删除了用户记录,并演示了如何进行软删除和物理删除。

期末放假自学Gin框架,希望我们可以一起学习!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/49269.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

新手小白的pytorch学习第八弹------分类问题模型和简单预测

目录 1 启动损失函数和优化器2 训练模型创建训练和测试循环 3 预测和评估模型 这篇是接着新手小白的pytorch学习第七弹------分类问题模型这一篇的,代码也是哟~ 1 启动损失函数和优化器 对于我们的二分类问题,我们经常使用 binary cross entropy 作为损…

机器视觉系列之【硬件知识】-工业相机(四)

目录 几个高频面试题目 工业彩色相机如何调节白平衡解决偏色问题 算法原理 多光谱成像技术和相机选型 多光谱相机技术 选择多光谱成像相机技术时的主要考虑因素 智慧工厂机器视觉感知与控制 1 智慧工厂与机器视觉检测控制技术 2 智慧工厂机器视觉感知与控制 基于机器视…

详解yolov5和yolov8以及目标检测相关面试

一、与yoloV4相比,yoloV5的改进 输入端:在模型训练阶段,使用了Mosaic数据增强、自适应锚框计算、自适应图片缩放基准网络:使用了FOCUS结构和CSP结构Neck网络:在Backbone和最后的Head输出层之间插入FPN_PAN结构Head输出…

[NOIP2009 提高组] 最优贸易(含代码题解)

[NOIP2009 提高组] 最优贸易 题目描述 C C C 国有 n n n 个大城市和 m m m 条道路,每条道路连接这 n n n 个城市中的某两个城市。任意两个城市之间最多只有一条道路直接相连。这 m m m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路&am…

NLP-使用Word2vec实现文本分类

Word2Vec模型通过学习大量文本数据,将每个单词表示为一个连续的向量,这些向量可以捕捉单词之间的语义和句法关系。本文做文本分类是结合Word2Vec文本内容text,预测其文本标签label。以下使用mock商品数据的代码实现过程过下: 1、…

JMeter的使用方法

软件安装: 参考链接:JMeter 下载安装及环境配置(包含jdk1.8安装及配置)_jmeter5.2.1需要什么版本的jdk-CSDN博客 前置知识储备: JMeter的第一个案例 增加线程数 线程(thread)是操作系统能够进…

ROS2入门到精通—— 2-8 ROS2实战:机器人安全通过狭窄区域的方案

0 前言 室内机器人需要具备适应性和灵活性,以便在狭窄的空间中进行安全、高效的导航。本文提供一些让机器人在狭窄区域安全通过的思路,希望帮助读者根据实际开发适当调整和扩展 1 Voronoi图 Voronoi图:根据给定的一组“种子点”&#xff0…

【数据挖掘】词云分析

目录 1. 词云分析 2. Python 中的 WordCloud 库 1. 词云分析 词云(Word Cloud)是数据可视化的一种形式,主要用于展示文本数据中单词的频率和重要性。它具有以下几种主要用途和意义: 1. 文本分析 • 识别关键主题:通…

AI学习记录 - 图像识别的基础入门

代码实现,图像识别入门其实非常简单,这里使用的是js,其实就是把二维数组进行公式化处理,处理方式如上图,不同的公式代表的不同的意义,这些意义网上其实非常多,这里就不细讲了。 const getSpecif…

JavaScript构造函数小挑战

// 编码挑战 #1 /* 使用构造函数实现一辆汽车。一辆汽车有一个品牌和一个速度属性。speed 属性是汽车当前的速度,单位为 km/h; a. 执行一个 “accelerate ”方法,将汽车的速度提高 10,并将新速度记录到控制台; 3. a.…

VSCode python autopep8 格式化 长度设置

ctrl, 打开设置 > 搜索autopep8 > 找到Autopep8:Args > 添加项--max-line-length150

等保测评练习卷17

等级保护初级测评师试题17 姓名: 成绩: 判断题(101=10分)1. 关于安全区域边界的安全审计,三级系统的要求包括应对审计进程进行保护,防止未经授权的中断。( F ) 是安全计算环境的安全审计 2.…

秋招突击——7/22——复习{堆——前K个高频元素}——新作{回溯——单次搜索、分割回文串。链表——环形链表II,合并两个有序链表}

文章目录 引言复习堆堆——前K个高频元素个人实现复习实现二参考实现 新作单词搜索个人实现参考实现 分割回文串个人实现参考实现 环形链表II个人实现参考实现 两个有序链表个人实现 总结 引言 又是充满挑战性的一天,继续完成我们的任务吧!继续往下刷&a…

WebRTC QoS方法十三.2(Jitter延时的计算)

一、背景介绍 一些报文在网络传输中,会存在丢包重传和延时的情况。渲染时需要进行适当缓存,等待丢失被重传的报文或者正在路上传输的报文。 jitter延时计算是确认需要缓存的时间 另外,在检测到帧有重传情况时,也可适当在渲染时…

【目标检测实验系列】EMA高效注意力机制,融合多尺度特征,助力YOLOv5检测模型涨点(文内附源码)

1. 文章主要内容 本篇博客主要涉及多尺度高效注意力机制,融合到YOLOv5s模型中,增加模型提取多尺度特征的能力,助力模型涨点。(通读本篇博客需要7分钟左右的时间)。 2. 简要概括 论文地址:EMA论文地址 如下…

Blender材质-PBR与纹理材质

1.PBR PBR:Physically Based Rendering 基于物理的渲染 BRDF:Bidirection Reflectance Distribution Function 双向散射分散函数 材质着色操作如下图: 2.纹理材质 左上角:编辑器类型中选择,着色器编辑器 新建着色器 -> 新建纹理 -> 新…

音视频入门基础:H.264专题(17)——FFmpeg源码获取H.264裸流文件信息(视频压缩编码格式、色彩格式、视频分辨率、帧率)的总流程

音视频入门基础:H.264专题系列文章: 音视频入门基础:H.264专题(1)——H.264官方文档下载 音视频入门基础:H.264专题(2)——使用FFmpeg命令生成H.264裸流文件 音视频入门基础&…

【开源库编译 | zlib】 zlib库最新版本(zlib-1.3.1)在Ubuntu(Linux)系统下的 编译 、交叉编译(移植)

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 🤣本文内容🤣&a…

《书生大模型实战营第3期》入门岛 学习笔记与作业:Git 基础知识

文章大纲 Git 是什么?-- 分布式版本控制系统版本控制系统简介Git 基本概念1. 安装 Git1.1 Windows 系统1.2 Linux 系统 2. Git 托管平台3. 常用 Git 操作4. tips4.1 全局设置 vs. 本地设置4.2 如何配置4.3 验证设置4.4 Git 四步曲 5. 常用插件6. 常规开发流程 作业其…

js+css侧边导航菜单 可收缩

jscss侧边导航菜单 可收缩https://www.bootstrapmb.com/item/14774 创建一个可收缩的侧边导航菜单需要使用JavaScript来处理交互&#xff0c;而CSS则用来设置样式和动画效果。以下是一个简单的示例&#xff0c;展示了如何创建一个可收缩的侧边导航菜单。 HTML 结构 html<!…