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

使用 GORM 与 MySQL 数据库进行交互来实现增删改查(CRUD)操作

1、安装 GORM 和 MySQL 驱动

新版本库是gorm.io/gorm

go get -u gorm.io/gorm
go get -u gorm.io/driver/mysql
2、连接 MySQL 数据库
package mainimport ("gorm.io/driver/mysql""gorm.io/gorm""log"
)func main() {// 数据源名称 (DSN) 格式:username:password@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Localdsn := "user:password@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})if err != nil {log.Fatalf("failed to connect database: %v", err)}log.Println("Connected to the MySQL database successfully.")
}

请根据实际情况替换 dsn 中的 user, password, 127.0.0.1:3306, dbname

3、定义模型

定义一个简单的模型,例如 Product,用于映射到数据库表。

type Product struct {gorm.ModelCode  stringPrice uint
}

这里的 gorm.Model 包含了 ID、CreatedAt、UpdatedAt 和 DeletedAt 字段。

4、完整示例
package mainimport ("log""gorm.io/driver/mysql""gorm.io/gorm"
)type Product struct {gorm.ModelCode  stringPrice uint
}func main() {dsn := "root:123456@tcp(127.0.0.1:3306)/test?charset=utf8mb4&parseTime=True&loc=Local"db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})if err != nil {log.Fatalf("failed to connect database: %v", err)}log.Println("Connected to the MySQL database successfully.")// 自动创建或迁移表db.AutoMigrate(&Product{})// 创建product := Product{Code: "D42", Price: 100}result := db.Create(&product)if result.Error != nil {log.Fatalf("Failed to create record: %v", result.Error)} else {log.Printf("Created product with ID: %d", product.ID)}// 查询var retrievedProduct Productif err := db.First(&retrievedProduct, 1).Error; err != nil {log.Printf("Product not found: %v", err)} else {log.Printf("Found product: %+v", retrievedProduct)}// 更新product.Price = 150result = db.Save(&product)if result.Error != nil {log.Fatalf("Failed to update record: %v", result.Error)} else {log.Printf("Updated product: %+v", product)}// 删除result = db.Delete(&product)if result.Error != nil {log.Fatalf("Failed to delete record: %v", result.Error)} else {log.Printf("Deleted product with ID: %d", product.ID)}
}

在这里插入图片描述

在这里插入图片描述

http://www.lryc.cn/news/495968.html

相关文章:

  • Day2 生信新手笔记: Linux基础
  • 001集—— 创建一个WPF项目 ——WPF应用程序入门 C#
  • 【C++】1___引用
  • 如何通过 JWT 来解决登录认证问题
  • 高效集成:将聚水潭数据导入MySQL的实战案例
  • Jenkins-基于 JNLP协议的 Java Web 启动代理
  • Qt数据库操作-QSqlQueryModel 的使用
  • C语言编程1.21波兰国旗问题
  • 如何利用微型5G网关为智慧无人矿车提供精确定位
  • 使用docker-compese部署SFTPGo详解
  • Ajax基础总结(思维导图+二维表)
  • Spring Task和WebSocket使用
  • 微信小程序 本地调试和vconsole可以 但在体验上页面不请求数据
  • QT:将QTableWidget内容写入txt文件中
  • 前端面试题(六)
  • 「Mac畅玩鸿蒙与硬件35」UI互动应用篇12 - 简易日历
  • Leetcode581. 最短无序连续子数组(HOT100)
  • HTML前端开发-- Flex布局详解及实战
  • 基于JWT跨语言开发分布式业务系统的挑战与实践:多语言协作的最佳方案
  • 二分法篇——于上下边界的扭转压缩间,窥见正解辉映之光(2)
  • 什么是 Kata Containers?
  • SpringMvc项目配置RabbitMq
  • shell编程(4)脚本与用户交互以及if条件判断
  • vue2组件跨层级数据共享provide 和 inject
  • springboot/ssm校园闲置物品交易系统ava大学生二手闲置交易平台web二手源码
  • Redis实现限量优惠券的秒杀
  • Linux centOS 7 安装 rabbitMQ
  • 活着就好20241202
  • 自由学习记录(28)
  • 操作系统、虚拟化技术与云原生01