我开源了Go语言连接数据库和一键生成结构体的包【实用】

项目地址https://gitee.com/zht639/my_gopkg

autosql

autosql 是一个简化数据库使用的模块,支持常见的数据库(MySQL、PostgreSQL、SQLite、SQL Server)。该模块不仅提供了数据库连接函数,还能自动生成数据表对应的结构体,极大简化了数据库的初始化操作。

一、使用方法

打开项目根目录,在该目录下打开命令行,然后按如下步骤操作。

(1)初始化mod(有则跳过此步)

bash 复制代码
go mod init 你的模块名

(2)下载包的最新版本(第一次下载可省略@master)

bash 复制代码
go get gitee.com/zht639/my_gopkg@master

(3)导包

go 复制代码
import "gitee.com/zht639/my_gopkg/autosql"

二、功能概述

  • 连接函数:

    • ConnMysql(username, password, host, port, dbname string): 连接 MySQL 数据库。
    • ConnPostgres(username, password, host, port, dbname string): 连接 PostgreSQL 数据库。
    • ConnSQLite(filepath string): 连接 SQLite 数据库。
    • ConnSQLServer(username, password, host, port, dbname string): 连接 SQL Server 数据库。
  • 结构体生成:

    • GenStruct(db *gorm.DB, tableName string): 生成数据库中指定表的结构体。
    • GenAllStructs(db *gorm.DB): 生成数据库中所有表的结构体。

    使用生成结构体功能可以将数据库中的表映射为 Go 语言的结构体,极大地提高了开发效率和代码的可维护性。

三、使用示例

以mysql为例,连接数据库并生成表的结构体:

go 复制代码
package main

import (
	"fmt"

	"gitee.com/zht639/my_gopkg/autosql"
)

func main() {
	db, err := autosql.ConnMysql("root", "123456", "localhost", "3306", "db01")
	if err != nil {
		fmt.Println(err)
		return
	}
	// 生成数据库中所有表的结构体
	autosql.GenAllStructs(db)
	//或者生成指定表对应的结构体
	//autosql.GenStruct(db, "student")
}

该函数将会在当前目录下生成一个model包,包含数据库中所有表的结构体,

目录结构如下:

bash 复制代码
├─model
│    grade.gen.go
│    student.gen.go
│    user.gen.go

打开其中一个文件,它不仅包含了结构体定义,还包含了json绑定字符串和返回表名的方法:

go 复制代码
// Code generated by gorm.io/gen. DO NOT EDIT.
// Code generated by gorm.io/gen. DO NOT EDIT.
// Code generated by gorm.io/gen. DO NOT EDIT.

package model

import (
	"time"
)

const TableNameStudent = "student"

// Student mapped from table <student>
type Student struct {
	Stuid int32     `gorm:"column:stuid;primaryKey;autoIncrement:true" json:"stuid"`
	Stuno string    `gorm:"column:stuno" json:"stuno"`
	Name  string    `gorm:"column:name" json:"name"`
	Sex   string    `gorm:"column:sex" json:"sex"`
	Age   int32     `gorm:"column:age" json:"age"`
	Birth time.Time `gorm:"column:birth" json:"birth"`
}

// TableName Student's table name
func (*Student) TableName() string {
	return TableNameStudent
}

之后若数据库中的表结构发生变化,只需用GenStruct()GenAllStructs()重新生成结构体即可。

注意

1.必须在mod同级目录调用GenStruct()或GenAllStructs()。

2.该包基于GORM相关的包,但本人的包已包含相关依赖,直接下载本人的包即可使用GORM。

相关推荐
Hgfdsaqwr4 小时前
使用Flask快速搭建轻量级Web应用
jvm·数据库·python
ruxshui4 小时前
Python多线程环境下连接对象的线程安全管理规范
开发语言·数据库·python·sql
OceanBase数据库官方博客4 小时前
客户案例|美的以OceanBase为基构建云中立数字化基座破局多云孤岛
数据库·oceanbase·分布式数据库
Mr_Xuhhh5 小时前
MySQL数据表操作全解析:从创建到管理
数据库·sql·oracle
大模型玩家七七5 小时前
向量数据库实战:从“看起来能用”到“真的能用”,中间隔着一堆坑
数据库·人工智能·python·深度学习·ai·oracle
OceanBase数据库官方博客5 小时前
基于分层协作多智能体的数据库参数调优——OceanBase 校企研究
数据库·oceanbase·分布式数据库
2301_763472465 小时前
使用PyQt5创建现代化的桌面应用程序
jvm·数据库·python
爱学习的阿磊5 小时前
Web开发与API
jvm·数据库·python
阳光九叶草LXGZXJ5 小时前
达梦数据库-学习-50-分区表指定分区清理空洞率(交换分区方式)
linux·运维·数据库·sql·学习
Data_Journal5 小时前
【无标题】
大数据·服务器·前端·数据库·人工智能