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

GORM 介绍及快速入门

GORM 介绍及快速入门

前言

GORM 是一个用 GoLang 语言编写的 ORM(对象关系映射)库。它被设计为开发者友好的方式来进行数据库操作。GORM 提供了一种高级的 API 来处理数据库的 CRUD(创建、读取、更新、删除)操作,它支持主流的关系型数据库,如 MySQL、PostgreSQL、SQLite 和 Microsoft SQL Server。

文档

GORM 指南

特性

使用 GORM,开发者可以使用 Go 的结构体来表示数据库中的表,结构体字段表示表的列。GORM 利用结构体和方法来映射数据库操作,大大减少了手写 SQL 查询的需要,简化了数据处理流程。

以下是 GORM 的一些主要特点:

  • 自动迁移:能够帮助管理数据库的迁移,例如自动创建、修改表结构。

  • CRUD 接口:提供了简单的方法来进行创建、读取、更新和删除操作。

  • 关联:支持一对一、一对多和多对多等关联关系,并可以很容易地操作相关联的数据。

  • 钩子:允许在特定的操作发生前后执行自定义逻辑。

  • 事务:对数据库事务提供了支持,保持数据的完整性。

  • 范围:允许定义常用的查询,以便可以重用。

  • SQL 构建器:即使是复杂的SQL查询,也可以通过GORM提供的接口构建。

  • 日志:记录所有的SQL操作,方便开发者调试和优化。

  • 扩展性:可以通过插件扩展其功能。

安装

go get -u gorm.io/gorm
go get -u gorm.io/driver/sqlite

快速入门

例如,使用 GORM,你可以这样定义一个模型和进行查询:

// 定义一个模型
type Product struct {gorm.ModelCode  stringPrice uint
}// 初始化
db, err := gorm.Open("sqlite3", "test.db")
if err != nil {panic("数据库连接失败")
}
defer db.Close()// 自动迁移
db.AutoMigrate(&Product{})// 创建
db.Create(&Product{Code: "L1212", Price: 1000})// 读取
var product Product
db.First(&product, 1) // 查询id为1的product
db.First(&product, "code = ?", "L1212") // 查询code为L1212的product// 更新 - 更新product的price为2000
db.Model(&product).Update("Price", 2000)// 删除 - 删除product
db.Delete(&product)

GORM 通过这种方式简化了数据库的操作,并使得代码更加简洁、易读和易维护。如果你在使用 Go 进行数据库操作,GORM 是一个不错的选择。

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

相关文章:

  • Scrcpy:掌握你的Android设备
  • [9, 8, 7, 6][1,2] = ?
  • docker部署Jira+配置MySQL8数据库
  • YOLOv5全网独家首发:DCNv4更快收敛、更高速度、更高性能,效果秒杀DCNv3、DCNv2等 ,助力检测实现暴力涨点
  • HTML中常用标签--详解
  • Vue实现字符串首字母大写、翻转字符串、获取用户选定的文本
  • 基于springboot+vue的旅游网站系统(前后端分离)
  • GB/T28181-2022之图像抓拍规范解读和设计实现
  • 阿赵UE学习笔记——10、Blender材质和绘制网格体
  • 数据结构--串
  • RabbitMQ交换机(3)-Topic
  • 前端密钥怎么存储,以及临时存储一些数据,如何存储才最安全?
  • 第16章_网络编程拓展练习(TCP编程,UDP编程)
  • 深入Docker5:安装nginx部署完整项目
  • HBASE学习四:常用命令汇总梳理(包括数据库、zk、hdfs相关操作与配置)
  • Android平台RTSP|RTMP播放端实时快照保存JPG还是PNG?
  • 【人工智能】之深入了解嵌入模型中的 Token:NLP 中的语义之旅(1)
  • UML-实现图(组件图和部署图)
  • 苹果Find My可查找添加32件物品,伦茨科技ST17H6x芯片加速产品赋能
  • postman后端测试时invalid token报错+token失效报错解决方案
  • 使用 mybatis-plus 的mybaits的一对多时, total和record的不匹配问题
  • SpringCloud之Nacos
  • 小封装高稳定性振荡器 Sg2520egn / sg2520vgn, sg2520ehn / sg2520vhn
  • 使用 Apache POI 更新/覆盖 特定的单元格
  • Spring Boot整合MyBatis-Plus
  • springboot项目之AOP角色权限的判断
  • Twincat PLC 跳出循环
  • 【Leetcode】277.搜寻名人
  • 小白数学建模 Mathtype 7.7傻瓜式下载安装嵌入Word/WPS以及深度使用教程
  • Linux之which和find