使用xorm工具,根据数据库自动生成 go 代码
2017-08-31 09:45
981 查看
使用xorm工具,根据数据库自动生成 go 代码
引入
使用 golang 操作数据库的同学都会遇到一个问题 —— 根据数据表结构创建对应的 struct 模型。因为 golang 的使用首字母控制可见范围,我们经常要设计 struct 字段名和数据库字段名的对应关系。久而久之,这是一个非常繁琐的过程。事情变得繁琐了,我们都会想,有没有好的办法自动生成 model 呢?今天,记录一种自动生成代码的方法 —— xorm 工具。关于 xorm
xorm是一个简单而强大的Go语言ORM库. 通过它可以使数据库操作非常简便。我在项目中经常使用,它的特性如下:支持Struct和数据库表之间的灵活映射,并支持自动同步表结构
事务支持
支持原始SQL语句和ORM操作的混合执行
使用连写来简化调用
支持使用Id, In, Where, Limit, Join, Having, Table, Sql, Cols等函数和结构体等方式作为条件
支持级联加载Struct
支持LRU缓存(支持memory, memcache, leveldb, redis缓存Store) 和 Redis缓存
支持反转,即根据数据库自动生成xorm的结构体
支持事件
支持created, updated, deleted和version记录版本(即乐观锁)
想了解更多请移步:http://www.xorm.io/
xorm 工具
xorm 是一组数据库操作命令的工具,包含如下命令:reverse 反转一个数据库结构,生成代码
shell 通用的数据库操作客户端,可对数据库结构和数据操作
dump Dump数据库中所有结构和数据到标准输出
source 从标注输入中执行SQL文件
driver 列出所有支持的数据库驱动
那我们该如何使用 reverse 命令根据数据表结构生成 go 代码呢?
首先我们要下载该工具 :
go get github.com/go-xorm/cmd/xorm
同时需要安装对应的 driver :
go get github.com/go-sql-driver/mysql //MyMysql go get github.com/ziutek/mymysql/godrv //MyMysql go get github.com/lib/pq //Postgres go get github.com/mattn/go-sqlite3 //SQLite
还需要下载 xorm :
go get github.com/go-xorm/xorm
编译
cmd/xorm会生成 xorm 工具, 假如环境变量。
这时候,执行
xorm help reverse能获取帮助信息如下:
usage: xorm reverse [-s] driverName datasourceName tmplPath [generatedPath] [tableFilterReg] according database's tables and columns to generate codes for Go, C++ and etc. -s Generated one go file for every table driverName Database driver name, now supported four: mysql mymysql sqlite3 postgres datasourceName Database connection uri, for detail infomation please visit driver's project page tmplPath Template dir for generated. the default templates dir has provide 1 template generatedPath This parameter is optional, if blank, the default value is model, then will generated all codes in model dir tableFilterReg Table name filter regexp
可以知道,执行参数 -s 表示为每张表创建一个单独文件。接下来的参数依次是:驱动,数据源,模板目录(在源码的
/cmd/xorm/templates/goxorm可根据需求定制),生成目录,表格过滤条件。
接下来我们以 Mysql 为例介绍使用方法。
xorm reverse mysql name:password@(ip:port)/xxx?charset=utf8 /cmd/xorm/templates/goxorm
这里输出目录参数省略,会在当前目录建立一个
model目录,该目录下就是自动生成的 go 代码,, 驼峰命名方式。具体内容如下:
package model type TestModel struct { Id int `json:"id" xorm:"not null pk autoincr INT(11)"` VpsName string `json:"vps_name" xorm:"VARCHAR(30)"` VpsIp string `json:"vps_ip" xorm:"CHAR(15)"` VpsPrivateIp string `json:"vps_private_ip" xorm:"CHAR(50)"` VpsCpu int `json:"vps_cpu" xorm:"INT(11)"` VpsMem int `json:"vps_mem" xorm:"INT(11)"` VpsDisk int `json:"vps_disk" xorm:"INT(11)"` VpsStatus string `json:"vps_status" xorm:"VARCHAR(255)"` LastHeartTime int `json:"last_heart_time" xorm:"INT(11)"` CreateTime int `json:"create_time" xorm:"INT(11)"` LastTime int `json:"last_time" xorm:"INT(11)"` }
到这里,就生成了我们想要的 model , 免去了手写的繁琐过程。
总结
照例总结一波,引用看到过一句话:如果一个工具能让我节省 1s 的时间,我愿意花一天的时间去找或者开发这个工具!
相关文章推荐
- 在MyEclipse的web项目/java项目中,使用Hibernate-tools中的hbm2java和hbm2ddl工具,根据hbm文件自动生成pojo和数据库脚本
- 使用CodeSmith根据数据库中的表自动生成WinUI界面(使用TableLayoutPanel布局)的代码.
- C#分析数据库结构,使用XSL模板自动生成代码
- 如何在Eclipse中使用ibatis的自动代码生成工具Abator
- C#分析数据库结构,使用XSL模板自动生成代码(二)
- 使用系统表根据存储过程名字生成ADO.NET数据库访问代码
- C#分析数据库结构,使用XSL模板自动生成代码
- [C#]一步一步开发自己的自动代码生成工具之一:获取SQL2005的数据库表结构
- 代码生成工具系列--------(三)根据数据库,生成存储过程
- 使用系统表根据存储过程名字生成ADO.NET数据库访问代码
- MySQL数据库使用Innodb数据库类型(工具生成Hibernate+Spring代码)
- C#分析数据库结构,使用XSL模板自动生成代码
- [导入]C#分析数据库结构,使用XSL模板自动生成代码
- ibatis - 自动代码生成工具abator 使用介绍(s00n原作)
- 根据数据库中的元数据自动生成实体类及iBatis相关的配置的工具
- C#分析数据库结构,使用XSL模板自动生成代码
- C#分析数据库结构,使用XSL模板自动生成代码
- C#分析数据库结构,使用XSL模板自动生成代码(一)
- 用Pytohn写了一个根据表结构自动生成C#对像代码的小工具
- C#分析数据库结构,使用XSL模板自动生成代码 - 清清月儿 .NET万花筒 Asp.net技术 Asp.net教程 Asp.net源码 Asp.net基础 Asp.net控件 Asp.net入门 - CSDNBlog