使用示例和应用程序全面了解高效数据管理的Golang MySQL数据库

news2024/10/6 16:17:42

在这里插入图片描述

Golang,也被称为Go,已经成为构建强大高性能应用程序的首选语言。在处理MySQL数据库时,Golang提供了一系列强大的库,简化了数据库交互并提高了效率。在本文中,我们将深入探讨一些最流行的Golang MySQL数据库库,通过实际示例来探索它们的功能。

1. GORM(github.com/go-gorm/gorm)

GORM是用于Golang的功能丰富的对象关系映射(ORM)库,通过提供直观的API来简化数据库操作。让我们看一个如何使用GORM的简单示例:

GORM示例

package main

import (
	"fmt"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

type User struct {
	ID   uint
	Name string
	Age  int
}

func main() {
	dsn := "user:password@tcp(localhost:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"
	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		panic("Failed to connect to database")
	}

	user := User{Name: "John", Age: 30}
	result := db.Create(&user)
	fmt.Println("Created user:", result.RowsAffected)
}

2. Go-MySQL-Driver(github.com/go-sql-driver/mysql)

Go-MySQL-Driver是Go的database/sql包的官方MySQL驱动程序。它提供了一种低级但高效的与MySQL数据库交互的方式。以下是如何使用Go-MySQL-Driver的基本示例:

Go-MySQL-Driver示例

package main

import (
	"database/sql"
	"fmt"
	_ "github.com/go-sql-driver/mysql"
)

func main() {
	dsn := "user:password@tcp(localhost:3306)/dbname"
	db, err := sql.Open("mysql", dsn)
	if err != nil {
		panic("Failed to connect to database")
	}
	defer db.Close()

	var name string
	err = db.QueryRow("SELECT name FROM users WHERE id = ?", 1).Scan(&name)
	if err != nil {
		panic(err)
	}

	fmt.Println("User's name:", name)
}

3. SQLX(github.com/jmoiron/sqlx)

SQLX是构建在Go的database/sql包之上的库,通过提供更简单的API和支持将查询结果直接映射到结构体来增强数据库交互。以下是一个简单的SQLX示例:

SQLX示例

package main

import (
	"fmt"
	"github.com/jmoiron/sqlx"
	_ "github.com/go-sql-driver/mysql"
)

type User struct {
	ID   int
	Name string
	Age  int
}

func main() {
	dsn := "user:password@tcp(localhost:3306)/dbname"
	db, err := sqlx.Connect("mysql", dsn)
	if err != nil {
		panic("Failed to connect to database")
	}
	defer db.Close()

	user := User{}
	err = db.Get(&user, "SELECT * FROM users WHERE id = ?", 1)
	if err != nil {
		panic(err)
	}

	fmt.Printf("User ID: %d, Name: %s, Age: %d\n", user.ID, user.Name, user.Age)
}

4. Beego(github.com/astaxie/beego/orm)

Beego是Go的流行Web框架,它包括支持各种数据库,包括MySQL的ORM包。以下是使用Beego ORM的示例:

Beego MySQL示例

package main

import (
	"fmt"
	"github.com/astaxie/beego/orm"
	_ "github.com/go-sql-driver/mysql"
)

type User struct {
	ID   int
	Name string
	Age  int
}

func init() {
	orm.RegisterDriver("mysql", orm.DRMySQL)
	orm.RegisterDataBase("default", "mysql", "user:password@tcp(localhost:3306)/dbname")
	orm.RegisterModel(new(User))
}

func main() {
	o := orm.NewOrm()

	user := User{ID: 1}
	err := o.Read(&user)
	if err == orm.ErrNoRows {
		fmt.Println("User not found")
	} else if err == nil {
		fmt.Printf("User ID: %d, Name: %s, Age: %d\n", user.ID, user.Name, user.Age)
	}
}

5. GORP(github.com/go-gorp/gorp)

GORP是另一个用于Golang的ORM库,它支持数据库交互和映射。它简化了CRUD操作和数据库迁移。以下是使用GORP与MySQL的示例:

GORP MySQL示例

package main

import (
	"fmt"
	"database/sql"
	_ "github.com/go-sql-driver/mysql"
	"gopkg.in/gorp.v2"
)

type User struct {
	ID   int
	Name string
	Age  int
}

func main() {
	dsn := "user:password@tcp(localhost:3306)/dbname"
	db, err := sql.Open("mysql", dsn)
	if err != nil {
		panic("Failed to connect to database")
	}
	defer db.Close()

	dbMap := &gorp.DbMap{Db: db, Dialect: gorp.MySQLDialect{}}
	
	user := User{}
	err = dbMap.SelectOne(&user, "SELECT * FROM users WHERE id = ?", 1)
	if err != nil {
		panic(err)
	}

	fmt.Printf("User ID: %d, Name: %s, Age: %d\n", user.ID, user.Name, user.Age)
}

6. Go-firestorm(github.com/firestorm-go/firestorm)

Go-firestorm是一个专注于与SQL数据库一起工作时的简单性和灵活性的库。它提供了一个易于使用的数据库交互API。以下是如何使用Go-firestorm的基本示例:

Go-firestorm MySQL示例

package main

import (
	"fmt"
	"github.com/firestorm-go/firestorm"
)

type User struct {
	ID   int    `db:"id"`
	Name string `db:"name"`
	Age  int    `db:"age"`
}

func main() {
	db, err := firestorm.New("mysql", "user:password@tcp(localhost:3306)/dbname")
	if err != nil {
		panic("Failed to connect to database")
	}
	defer db.Close()

	var user User
	err = db.SelectOne(&user, "SELECT * FROM users WHERE id = ?", 1)
	if err != nil {
		panic(err)
	}

	fmt.Printf("User ID: %d, Name: %s, Age: %d\n", user.ID, user.Name, user.Age)
}
  1. SQLBoiler(github.com/volatiletech/sqlboiler)

SQLBoiler是一个从数据库模式生成Go代码的ORM。它旨在减少数据库交互所需的样板代码量。以下是如何使用SQLBoiler的示例:

SQLBoiler示例

# Install SQLBoiler
go install github.com/volatiletech/sqlboiler/v4@latest

# Generate code based on the database schema
sqlboiler mysql

User 表的生成代码:

package models

import "time"

type User struct {
	ID        int       `boil:"id" json:"id" toml:"id" yaml:"id"`
	Name      string    `boil:"name" json:"name" toml:"name" yaml:"name"`
	Age       int       `boil:"age" json:"age" toml:"age" yaml:"age"`
	CreatedAt time.Time `boil:"created_at" json:"created_at" toml:"created_at" yaml:"created_at"`
	UpdatedAt time.Time `boil:"updated_at" json:"updated_at" toml:"updated_at" yaml:"updated_at"`
	DeletedAt time.Time `boil:"deleted_at" json:"deleted_at" toml:"deleted_at" yaml:"deleted_at"`
}

总结

Golang的MySQL数据库库提供了一系列功能和能力,可以简化数据库交互并增强应用程序的效率。无论您是寻找像GORM或SQLBoiler这样的ORM,像Go-MySQL-Driver这样的驱动程序,像SQLX或Go-firestorm这样的简单API,还是与Web框架像Beego或GORP集成,都有适合您需求的库。通过利用这些库,您可以专注于构建应用程序的逻辑,而不会陷入数据库管理的复杂性中。

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

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

相关文章

ImportError: DLL load failed while importing _pyopenvino: 找不到指定的程序

ImportError: DLL load failed while importing _pyopenvino: 找不到指定的程序 完全按照官方的pip安装方式,但是报错 解决方法: 下载下面压缩包 官网下载链接 解压到 运行程序之前 完成!!! 测试 python -c &quo…

思维模型 纳什均衡

本系列文章 主要是 分享 思维模型,涉及各个领域,重在提升认知。纳什均衡解释了囚徒困境、智猪博弈、内卷、美苏的军备竞赛等博弈问题。 1 纳什均衡的应用 1.1 经典的 囚徒困境 1 背景 囚徒困境是一个经典的博弈论问题,主要描述了两个被捕的…

第十三章 枚举与泛型

13.1枚举类型 13.1.1 使用枚举类型设置常 设置常量时,通常将常量放置在接口中,这样在程序中直接使用。该常量不能被修改,因为在接口定义常量时,该常量的修饰符为final与static。常规定义常量的代码如下: public int…

Stable Diffusion系列(一):古早显卡上最新版 WebUI 安装及简单操作

文章目录 Stable Diffusion安装AnimateDiff插件适配sdxl模型适配 Stable Diffusion使用插件安装界面设置基础文生图加入lora的文生图 Stable Diffusion安装 我的情况比较特殊,显卡版本太老,最高也就支持cuda10.2,因此只能安装pytorch1.12.1&…

05、SpringCloud -- 秒杀按钮、秒杀请求流程(各种请求到后台的判断、减库存、下单数据和次数保存)

目录 秒杀按钮代码实现:vue的JS实现:秒杀请求需求:代码前端后端Seckill-apidomainSeckill-serverWebConfig1、秒杀请求判断controller2、重复下单判断MapperService 接口Impl 实现类controller3、库存判断4、秒杀涉及到的操作_01、减库存_02、创建订单对象并保存_03、用户下…

mycat2.X读写分离

一、数据库中间件介绍 二、下载安装包 2.1下载地址: 下载两个一个是mycat程序,一个是mycat的驱动 http://dl.mycat.org.cn/2.0/install-template/mycat2-install-template-1.20.zip http://dl.mycat.org.cn/2.0/1.21-release/mycat2-1.21-release-jar-with-dependencies-2…

电子邮件钓鱼攻击的防范:如何识别并避免网络诈骗

在数字化的今天,电子邮件成为我们日常工作和生活中不可或缺的通讯工具。然而,电子邮件钓鱼攻击也随之成为网络诈骗的常见手法。通过识别和避免电子邮件钓鱼攻击,我们可以在很大程度上保护自己的网络安全。本文将为您提供一些实用的识别和防范…

nacos在linux中的安装、集群的配置、mysql生产配置

1.下载和安装 官方下载地址:https://github.com/alibaba/nacos/releases,根据自己需要的本版去下载就行 下载的是 .tar.gz 后缀的文件是linux版本的 使用tar命令解压,完成之后是一个nacos的文件夹 和windows下的文件夹目录是一样的 要启…

小黑子—spring:第三章 AOP开发

spring入门3.0 三 小黑子的springAOP开发1. AOP简介1.1 AOP的概念1.2 AOP思想的实现方案1.3 模拟AOP思想实现的基础代码1.4 AOP的相关概念 2. 基于xml配置的AOP2.1 XML方式AOP快速入门2.2 XML方式AOP配置详解2.3 xml方式AOP的原理解析2.3.1 AOP底层两种生成Proxy的方式 3. 基于…

一个老旧优盘从2M变回8G的逆袭之路

前言 最近收拾资料,发现了一个比较老的优盘,上面标记8G内存,就好奇里边存了点啥。用电脑打开,啥内容都没有,结果大小还显示2M???看看今天能不能救活吧。 正文 步骤一、清空磁盘 …

并发安全问题之超卖问题

并发安全问题之超卖问题 乐观锁总结: 优点:不加锁性能好。 缺点:同时请求成功率低(即只要发现数据变了就放弃了)。 乐观锁思想的具体体现:一共两步,第一步,先查询状态。第二步&…

Java VMTranslator Part I

目录 堆栈运算命令 基本思路 核心代码 Parser Code Writer Main 实验结果,使用SimpleAdd、StackTest进行验证 内存访问命令 基本思路 核心代码 Parser Code Writer Main 实验结果,使用进行验证。对比生成的二进制代码文件。 用Java写一个翻…

MySQL6:索引使用原则,联合索引,联合主键/复合主键,覆盖索引、什么是回表?索引条件下推,索引的创建与使用,索引的创建与使用,索引失效

MySQL6:索引使用原则,联合索引,联合主键/复合主键,覆盖索引、什么是回表?索引条件下推,索引的创建与使用,索引的创建与使用,索引失效 索引使用原则列的离散(sdn)度 联合索引创建联合…

【C++初探:简单易懂的入门指南】二

【C初探:简单易懂的入门指南】二 1.引用1.1引用做函数的参数1.2 引用做返回值1.2.1 关于引用做返回值的几点补充 1.3 多引用(对一个变量取多个别名)1.4 引用类型一致性原则以及权限的问题阐述1.5引用的效率问题1.6引用和指针的比较 2.auto关键字2.1 auto关键字的使用…

BSTree二叉树讲解

二叉搜索树的概念: 二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树: 若它的左子树不为空,则左子树上所有节点的值都小于根节点的值 若它的右子树不为空,则右子树上所有节点的值…

重置 VCSA 6.7 root密码和SSO密码

原贴地址:https://www.cnblogs.com/airoot/p/16059033.html 问题描述 1、用root用户登录 VMware vCenter Server Appliance虚拟机失败,无法登录 2、vCenter Server Appliance 6.7 U1的root帐户错误尝试次数超过3次已锁定或帐户已过期 官方说明 在VC…

【Spring Boot 源码学习】RedisAutoConfiguration 详解

Spring Boot 源码学习系列 RedisAutoConfiguration 详解 引言往期内容主要内容1. Spring Data Redis2. RedisAutoConfiguration2.1 加载自动配置组件2.2 过滤自动配置组件2.2.1 涉及注解2.2.2 redisTemplate 方法2.2.3 stringRedisTemplate 方法 总结 引言 上篇博文&#xff0…

【C++基础入门】44.C++中对象模型分析(上)

一、回归本质 class 是一种特殊的 struct 在内存中 class 依旧可以看作变量的集合class 与 struct 遵循相同的内存对齐规则class 中的成员函数与成员变量是分开存放的 每个对象有独立的成员变量所有对象共享类中的成员函数值得思考的问题 下面看一个对象内存布局的代码&#x…

Go学习第十七章——Gin中间件与路由

Go web框架——Gin中间件与路由 1 单独注册中间件1.1 入门案例1.2 多个中间件1.3 中间件拦截响应1.4 中间件放行 2 全局注册中间件3 自定义参数传递4 路由分组4.1 入门案例4.2 路由分组注册中间件4.3 综合使用 5 使用内置的中间件6 中间件案例权限验证耗时统计 1 单独注册中间件…

Java项目之网络考试系统

视频教程: 01-创建数据库_哔哩哔哩_bilibili 源码下载:百度网盘 请输入提取码 准备工作 创建数据库配置IDEA后端导入前端 前言: 把代码掰开写进博客里,主要是让自己在整理笔记的过程中,多去思考完成这个功能的核心…