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

news2024/11/15 17:24:15

目录

GORM的CRUD教程

更新操作

更新所有字段

更新指定字段

使用 Select 和 Omit 更新

无 Hooks 更新

批量更新

删除操作

删除记录

批量删除

软删除

物理删除

示例代码

GORM的CRUD教程

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

更新操作

更新所有字段

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

type User struct {
    gorm.Model
    Name string
    Age  int
}

func main() {
    db, err := gorm.Open(/* 连接数据库的参数 */)
    if err != nil {
        log.Fatal(err)
    }

    // 假设已经从数据库中获取了用户数据
    var user User
    db.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 main

import (
    "gorm.io/driver/sqlite"
    "gorm.io/gorm"
    "gorm.io/gorm/logger"
    "log"
)

type User struct {
    gorm.Model
    Name string
    Age  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 = 31
    db.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.coloradmin.cn/o/1944946.html

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

相关文章

百度,有道,谷歌翻译API

API翻译 百度,有道,谷歌API翻译(只针对中英相互翻译),其他语言翻译需要对应from,to的code 百度翻译 package fills.tools.translate; import java.util.ArrayList; import java.util.HashMap; import java.util.Lis…

windows服务器启动apache失败,提示请通过cmd命令行启动:net start apache

Windows Server 2012 R2服务器突然停止运行apche,启动apache失败,提示请通过cmd命令行启动:net start apache 1.报错截图: 进入服务里输入命令启动也不行,提示由于登录失败而无法启动服务。 2.问题原因: 服务器www用…

数据库(MySQL)-DQL数据查询语言

DQL(Data Query Language 数据查询语言)的用途是查询数据库数据,如select语句。其中,可以根据表的结构和关系分为单表查询和多表联查。 单表查询 单表查询:针对数据库中的一张数据表进行查询 全字段查询 语法:select 字段名 fro…

User Allocation In MEC: A DRL Approach 论文笔记

论文:ICWS 2021 移动边缘计算中的用户分配:一种深度强化学习方法 代码地址:使用强化学习在移动边缘计算环境中进行用户分配 目录 Ⅰ.Introduction II. MOTIVATION-A.验证假设的观察结果 II. MOTIVATION-A Motivating Example 数据驱动…

我在百科荣创企业实践——简易函数信号发生器(5)

对于高职教师来说,必不可少的一个任务就是参加企业实践。这个暑假,本人也没闲着,报名参加了上海市电子信息类教师企业实践。7月8日到13日,有幸来到美丽的泉城济南,远离了上海的酷暑,走进了百科荣创科技发展有限公司。在这短短的一周时间里,我结合自己的教学经验和企业的…

C#,.NET常见算法

1.递归算法 1.1.C#递归算法计算阶乘的方法 using System;namespace C_Sharp_Example {public class Program{/// <summary>/// 阶乘&#xff1a;一个正整数的阶乘Factorial是所有小于以及等于该数的正整数的积&#xff0c;0的阶乘是1&#xff0c;n的阶乘是n&#xff0…

【学习笔记】无人机系统(UAS)的连接、识别和跟踪(五)-无人机跟踪

目录 引言 5.3 无人机跟踪 5.3.1 无人机跟踪模型 5.3.2 无人机位置报告流程 5.3.3 无人机存在监测流程 引言 3GPP TS 23.256 技术规范&#xff0c;主要定义了3GPP系统对无人机&#xff08;UAV&#xff09;的连接性、身份识别、跟踪及A2X&#xff08;Aircraft-to-Everyth…

Samtec技术科普小课堂 | 一文入门射频连接器~

【摘要/前言】 在本文中&#xff0c;我们将回到基础知识&#xff0c;了解一下什么是射频连接器。如果您是信号完整性专家&#xff0c;请点击阅读原文访问我们的网站视频&#xff0c;通过我们的网络研讨会视频了解教科书上可能找不到的知识。 如果您是电气工程领域的新手&#…

Prometheus 监控Tomcat等java应用的状态

5月应用服务出现问题&#xff0c;当别的小伙伴问我&#xff0c;有没有Tomcat等应用状态的监控的时候&#xff0c;我有点儿尴尬。所以赶紧抽空部署一下。 在配置之前&#xff0c;就当已经会安装jdk和tomcat了。 一、下载jmx_exporter #linux下 cd /usr/local/prometheus wget …

新增ClamAV病毒扫描功能、支持Java和Go运行环境,1Panel开源面板v1.10.12版本发布

2024年7月19日&#xff0c;现代化、开源的Linux服务器运维管理面板1Panel正式发布了v1.10.12版本。 在这一版本中&#xff0c;1Panel新增了多项实用功能。社区版方面&#xff0c;1Panel新增ClamAV病毒扫描功能、支持Java和Go运行环境&#xff0c;同时1Panel还新增了文件编辑器…

浪潮GS企业管理软件GetChildFormAndEntityList存在反序列化漏洞

一、漏洞简介 浪潮GS 面向大中型集团企业采用SOA 架构和先进开放的GSP 应用中间件开发,形成了集团管控13 大领域15 大行业60余个细分行业的解决方案。在管理方面,浪潮GS 有效帮助企业有效实现财务集中管理、资金集中管理、资产集中管理、供应链集中管理,从而达到集团信息的…

案例|华能某风电场配电房智能巡检机器人解决方案

随着风电产业的迅猛发展&#xff0c;风电场内配电房是风电场电能传输和转换的关键节点&#xff0c;其设备运行状况直接影响到风电场的整体运行效率和安全性。传统的人工巡检方式存在效率低、误差大、安全风险高等问题&#xff0c;难以满足现代风电场对高效、可靠运维的需求。智…

第一百七十二节 Java IO教程 - Java I/O缓冲区

Java IO教程 - Java I/O缓冲区 什么是NIO&#xff1f; 在NIO中&#xff0c;我们处理I/O操作的通道和缓冲区。 像流一样的通道表示数据源/接收器和用于数据传输的Java程序之间的连接。 通道提供双向数据传输设施。我们可以使用通道来读取数据以及写入数据。根据我们的需要&a…

【python】Python常见的面试题解析:深入探索与实践,助你少走弯路

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

Redis分布式系统中的主从复制

本篇文章主要对Redis的主从复制进行讲解。主要分析复制的原理&#xff0c;包括:建立复制、全量复制、部分复制、全量复制、心跳检测等。希望本篇文章会对你有所帮助。 文章目录 一、主从复制简介 二、配置主从复制模式 断开主从复制 安全性 只读 传输延迟 三、拓扑结构 四、主…

秋招复习笔记——八股文部分:网络TCP

TCP 三次握手和四次挥手 TCP 基本认识 序列号&#xff1a;在建立连接时由计算机生成的随机数作为其初始值&#xff0c;通过 SYN 包传给接收端主机&#xff0c;每发送一次数据&#xff0c;就「累加」一次该「数据字节数」的大小。用来解决网络包乱序问题。 确认应答号&#xf…

字符的统计——423、657、551、696、467、535

423. 从英文中重建数字 最初思路 首先要有一个指针&#xff0c;对于3/4/5为一组地跳跃。起初想的是后瞻性&#xff0c;如果符合0-9任意&#xff0c;则更换index、跳跃。此时写了一个函数&#xff0c;用来判断s的截取段和0-9中有无符合。这个思路并没有进行下去&#xff0c;虽然…

C++ - 基于多设计模式下的同步异步⽇志系统

1.项目介绍 项⽬介绍 本项⽬主要实现⼀个⽇志系统&#xff0c; 其主要⽀持以下功能: • ⽀持多级别⽇志消息 • ⽀持同步⽇志和异步⽇志 • ⽀持可靠写⼊⽇志到控制台、⽂件以及滚动⽂件中 • ⽀持多线程程序并发写⽇志 • ⽀持扩展不同的⽇志落地⽬标地 2.开发环境 • Cent…

第二证券:净现比是什么?怎么计算?

1、净现比的含义 净现比是指运营活动产生的现金净流量与净获利的百分比&#xff0c;是用来衡量企业实在盈利才干的目标。净现比也叫做净获利现金含量&#xff0c;即企业的净获利中&#xff0c;有多少转化成现金进入我们的钱包。 2、净现比的核算 净现比的核算公式为&#xf…

聊聊预训练模型的微调

前言 Transformers 提供了一个 Trainer 类&#xff0c;处理微调在数据集上提供的任何预训练模型。 完成所有数据预处理工作后&#xff0c;只需执行几个步骤即可定义 Trainer。 最困难的部分可能是准备运行 Trainer.train() 的环境&#xff0c;因为它在 CPU 上运行速度非常慢。…