xorm根据数据库生成go model文件

本文介绍如何使用xorm工具将数据库表结构逆向生成为Go语言的结构体,涵盖安装配置及各数据库类型的驱动说明,并提供具体命令实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

你懂的,手工翻译表定义到go结构体是很枯燥的。
so,用xorm搞定。

go get github.com/go-xorm/cmd/xorm

安装以下依赖,用到哪个装哪个。

github.com/go-xorm/xorm

驱动

  1. Mysql: github.com/go-sql-driver/mysql
  2. MyMysql: github.com/ziutek/mymysql/godrv
  3. Postgres: github.com/lib/pq
  4. SQLite: github.com/mattn/go-sqlite3
  5. MSSQL: github.com/denisenkom/go-mssqldb
    逆向生成
    Reverse 命令可以转换数据库到所有支持的语言的数据结构,安装以后可以用 xorm help reverse查看帮助。

例子:

cd $GOPATH/src/github.com/go-xorm/cmd/xorm

sqlite: xorm reverse sqite3 test.db templates/goxorm

mysql: xorm reverse mysql root:root@/xorm_test?charset=utf8 templates/goxorm

mymysql: xorm reverse mymysql xorm_test2/root/ templates/goxorm

postgres: xorm reverse postgres "dbname=xorm_test sslmode=disable" templates/goxorm

mssql: xorm reverse mssql "server=test;user id=testid;password=testpwd;database=testdb" templates/goxorm

会在./model目录下生成go的文件

  1. 一定要在$GOPATH/src/github.com/go-xorm/cmd/xorm目录下运行,因为在这个目录下有templets,在解析数据库结构的时候有用。如果在别的目录下运行,会导致命令不报错,但是无法正常生成对应的结构文件。有空可以给github.com/go-xorm/cmd/xorm提个bug,加上错误提示。
  2. 执行xorm reverse mysql root:root@tcp\(127.0.0.1:3306\)/testdb?charset=utf8 templates/goxorm
Go语言中,使用xorm库连接数据库通常涉及以下几个步骤,包括设置跳板机(如果需要)。假设您正在使用SSH作为跳板机: 1. 安装依赖:首先确保您的Go环境已安装并设置了`GOPATH`。然后,通过`go get`命令安装xorm库和其他必要的驱动包(如`github.com/go-sql-driver/mysql`等对应于您的目标数据库的包)。 ```bash go get github.com/go-xorm/xorm go get golang.org/x/crypto/ssh ``` 2. 配置基础连接信息:创建一个数据库连接配置,这可能包含数据库地址、用户名、密码等基本信息,以及是否通过跳板机。例如,如果跳板机的地址是`jumpbox.example.com`,端口是22,数据库服务器是`db.example.com`,可以这样表示: ```go import ( "golang.org/x/crypto/ssh" "net/http" ) // 跳板机配置 jumpHost := &ssh.ClientConfig{ User: "your-jump-user", Auth: []ssh.AuthMethod{ ssh.Password("your-jump-password"), }, HostKeyCallback: ssh.InsecureIgnoreHostKey(), } // 数据库主机配置 dbHost := "db.example.com:port" ``` 3. 连接中间层(跳板机):使用`ssh.Dial`函数建立到跳板机的连接: ```go sshClient, err := ssh.Dial("tcp", jumpHost.Host+":"+strconv.Itoa(jumpHost.Port), jumpHost) if err != nil { // 处理错误... } defer sshClient.Close() session, err := sshClient.NewSession() if err != nil { // 处理错误... } defer session.Close() stdin, stdout, stderr := session.Stdin(), session.Stdout(), session.Stderr() ``` 4. 中间层隧道:利用SSH通道创建一个透明到数据库服务器的TCP连接: ```go localPort, err := session.RequestPty("xterm") if err != nil { // 处理错误... } remotePort := dbHostPort tunnelCmd := fmt.Sprintf("nc -l %d | nc %s %d", localPort, dbHost, remotePort) _, err = stdin.WriteString(tunnelCmd + "\n") if err != nil { // 处理错误... } err = session.Wait() if err != nil { // 处理错误... } ``` 5. 使用xorm库连接数据库:现在您可以使用`http.Transport`包装SSH连接,并通过它来构建xorm的DB实例: ```go transport := &http.Transport{ dialContext: func(ctx context.Context, network, addr string) (net.Conn, error) { conn, _, err := netTransport.Dial(network, addr) if err != nil { return nil, err } conn = sshProxy(conn, tunnelStdout) return conn, nil }, } db, err := xorm.NewEngine("mysql", "user:password@unix("+dbHost+",3306)/dbname?charset=utf8&parseTime=True&loc=Local") if err != nil { // 处理错误... } ``` 请注意,这里有一个简化示例,实际生产环境中还需要处理更多细节,比如错误处理、认证安全等问题。此外,`sshProxy`函数和`netTransport`需要你自己实现,它们分别用于处理SSH连接和原生网络连接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值