网上的包过于繁琐复杂。所以写个简单。mysql的多种数据类型没有全部实现转化。可以编译成可执行文件。

package main

import (
"flag"
"fmt"
"io"
"os"
"strings"
"gorm.io/gorm"
"gorm.io/driver/mysql" ) var db *gorm.DB func main() {
var host string
var user string
var pass string
var database string
var table string
var pack string
// 端口
var port string flag.StringVar(&host,"h","","数据库地址")
flag.StringVar(&pass,"p","","密码")
flag.StringVar(&user,"u","","用户")
flag.StringVar(&database,"d","","数据库")
flag.StringVar(&table,"t","","表名")
flag.StringVar(&port,"P","","端口")
flag.StringVar(&pack,"k","","端口")
// 解析
flag.Parse()
dsn := fmt.Sprintf(
"%s:%s@tcp(%s)/%s?parseTime=True&loc=Local",
user,
pass,
host,
database,
)
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
fmt.Println(err)
}
type Field struct {
Field string `gorm:"column:Field"`
Type string `gorm:"column:Type"`
Comment string `gorm:"column:Comment"`
}
var fieldObj []Field
packageName := fmt.Sprintf("package %s\n\n", pack)
structName := toUp(table)
sns := fmt.Sprintf("type %s struct {", structName)
file := packageName + sns
sql := fmt.Sprintf("SELECT TABLE_NAME, COLUMN_COMMENT as Comment, COLUMN_NAME as Field, DATA_TYPE as Type from INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='%s';", table)
db.Raw(sql).Scan(&fieldObj)
for _, value := range fieldObj {
f := fmt.Sprintf("\n\t%s %s `json:\"%s\"` // %s ", toUp(value.Field), getType(value.Type), value.Field, value.Comment )
file = file + f
}
sne := "\n}"
file = file + sne
tableName := fmt.Sprintf("\n\nfunc (%s) TableName() string {\n\treturn \"%s\"\n}" , structName, table )
file = file + tableName
fileName := fmt.Sprintf("%s.go", structName)
fileInfo, er := os.Stat(fileName)
if er == nil {
// 存在就是不允许覆盖
if fileInfo.Size() != 0 {
fmt.Println("文件已存在!")
return
}
} f, e := os.Create(fileName)
if e != nil {
fmt.Println("打开文件错误", e)
return
}
_, we := io.WriteString(f, file)
if we != nil {
fmt.Println("写入文件错误", we )
return
} } func toUp( field string ) string {
var nextUp bool
str := ""
for key, value := range field {
if key == 0 {
str = str + strings.ToUpper(string(value))
continue
}
if string(value) == "_" {
nextUp = true
continue
}
if nextUp {
str = str + strings.ToUpper(string(value))
nextUp = false
} else {
str = str + string(value)
}
} return str } func getType( typeString string ) string {
i := strings.Index(typeString, "(")
if i < 0 {
i = len(typeString) - 1
} t := typeString[:i]
m := map[string]string{
"tinyint" : "int64",
"smallint" : "int64",
"mediumint" : "int64",
"int" : "int64",
"bigint" : "int64",
"float" : "float64",
"decimal" : "string",
"bit" : "string",
"year" : "string",
"time" : "string",
"date" : "string",
"datetime" : "string",
"timestamp" : "string",
"char" : "string",
"varchar" : "string",
"tinytext" : "string",
"text" : "string",
"mediumtext" : "string",
"longtext" : "string",
"enum" : "string",
// 其他类型默认转字符
}
if val, ex := m[t]; ex {
return val
} else {
return "string"
}
}

示例执行命令:

 go run main.go  -h 127.0.0.1  -P 3306 -u test -p passwrod -d db -t table -k module

释义:

根据指定的数据库地址表名,在当前目录下为表生成 package 名为module 的go文件。

golang 用gorm生成module文件的更多相关文章

  1. Wix 安装部署(一)同MSBuild 自动生成打包文件

    因为项目需要,最近在研究Wix打包部署,园子里也有一些关于wix的博客,方方面面,讲的点各不同.我自己也在测试过程中,写下过程,以供参考.最新版本WiX Toolset v3.7,如何安装的就不说了, ...

  2. Wix 安装部署(一)同MSBuild 自动生成打包文件 转

    原文地址:http://www.cnblogs.com/stoneniqiu/p/3355086.html 因为项目需要,最近在研究Wix打包部署,园子里也有一些关于wix的博客,方方面面,讲的点各不 ...

  3. 【Android Studio安装部署系列】二十五、Android studio使用NDK生成so文件和arr文件

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 Android Studio使用ndk的简单步骤. NDK环境搭建 下载NDK 下载链接:https://developer.and ...

  4. webpack4 系列教程(十三):自动生成HTML文件

    作者按:因为教程所示图片使用的是 github 仓库图片,网速过慢的朋友请移步<webpack4 系列教程(十三):自动生成 HTML 文件>原文地址.更欢迎来我的小站看更多原创内容:go ...

  5. pyx文件 生成pyd 文件用于 cython调用

    转于:https://www.2cto.com/kf/201405/304168.html 1. 初衷 最近学用python,python不愧是为程序员考虑的编程语言,写起来很快很方便,大大节省开发效 ...

  6. Yii2用Gii自动生成Module+Model+CRUD

    1. 开启gii模块 common/config/main-local.php加入下面代码 return [ 'modules' => [ 'gii' => [ 'class' => ...

  7. Python中使用dom模块生成XML文件示例

    在Python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文件,下一篇文章再继续介绍Dom解析XML文件. 在生成XML文件中,我们主 ...

  8. Python:Dom生成XML文件(写XML)

    http://www.ourunix.org/post/327.html 在python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文 ...

  9. PowerDesigner通过SQL语句生成PDM文件并将name和comment进行互相转换

    本篇文章主要介绍了PowerDesigner通过SQL语句生成PDM文件并将name和comment进行互相转换 超详细过程(图文),具有一定的参考价值,感兴趣的小伙伴们可以参考一下 1.软件准备 软 ...

  10. webpack中使用html-webpack-plugin生成HTML文件并主动插入css和js引入标签

    html-webpack-plugin clean-webpack-plugin 一.html-webpack-plugin 由于打包时生成的css样式文件和js脚本文件会采用hash值作为文件命名的 ...

随机推荐

  1. 行为型模式 - 迭代器模式iterator

    模式的定义与特点 迭代器模式(iterator Pattern),为的提是可以顺序访问一个聚集中的元素而不必暴露聚集的内部表象.多个对象聚在一起形成的总体称之为聚集,聚集对象是能够包容一组对象的容器对 ...

  2. 【FAQ】申请运动健康服务验证环节常见问题及解答

    华为 HMS Core 运动健康服务(HUAWEI Health Kit)提供原子化数据开放.应用在获取用户数据授权后,可通过接口访问运动健康数据,对用户数据进行读写等操作,为用户提供运动健康类数据服 ...

  3. 简述 Gin 框架如何集成swagger

    https://blog.csdn.net/raogeeg/article/details/86743953 @Title           这个 API 所表达的含义,是一个文本,空格之后的内容全 ...

  4. Python+chatGPT编程5分钟快速上手,强烈推荐!!!

    最近一段时间chatGPT火爆出圈!无论是在互联网行业,还是其他各行业都赚足了话题. 俗话说:"外行看笑话,内行看门道",今天从chatGPT个人体验感受以及如何用的角度来分享一下 ...

  5. Python学习常见问题及其解决方案(1)

    1.ModuleNotFoundError: No module named 'urllib2' 解决方案: 1)https://blog.csdn.net/weixin_45598506/artic ...

  6. Docker中Mysql容器忘记密码的处理方法

    今天非常的倒霉,因为学习了Vue的相关知识,想自己写一个后端服务器来练习一下Vue 然后 忘记了Docker中Mysql的密码... 很抽象 下面是我的解决方法 一.如果在本地的Navicat Pre ...

  7. 「SHOI2015」脑洞治疗仪

    \(\text{Naive Solition}\) 当然是 \(ODT\) 暴力啦 \(Luogu\) 煞费苦心加强了数据,于是就过不了了... 不过 \(LibreOJ\) 上可以过 #includ ...

  8. JZOJ 4250.路径

    \(\text{Solution}\) \(30\) 分暴搜合法路径 另 \(30\) 分状压 设 \(f_{i,j,k}\) 表示当前到第 \(i\) 个点,走过的点状态为 \(j\),走过的路径长 ...

  9. 自己从零写操作系统GrapeOS系列教程——4.GrapeOS开发环境介绍

    1. 开发环境简介 为了减少开发过程中不必要的麻烦,希望大家的开发环境尽量与我的保持一致. 我的开发环境如下: Windows10电脑一台 Visual Studio Code(最好是最新版) Vir ...

  10. “堆内存持续占用高 且 ygc回收效果不佳” 排查处理实践

    作者:京东零售 王江波 说明:部分素材来源于网络,数据分析全为真实数据. 一. 问题背景 自建的两套工具,运行一段时间后均出现 内存占用高触发报警,频繁young gc且效果不佳.曾经尝试多次解决,因 ...