Golang Beego Api连接Mysql简单示例(集成Swagger和Convey单测)

FredricZhu · · 1234 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

1.工程创建步骤如下,
https://beego.me/blog/beego_api
如要集成swagger,请注意使用下面的语句启动beego。

bee run -downdoc=true -gendoc=true 

2.连接mysql数据库。
先要安装两个包,
如下,

go get github.com/astaxie/beego/orm go get github.com/go-sql-driver/mysql 

其次有一个坑,就是必须要先建一个别名为default的数据库,才能启动连接。
而且这个建库的操作最好是在models里面,实测的话,框架先加载models,然后才去运行main包里面的init函数,单元测试直接测试models也是只加载models。
另一个问题是RegisterDatabase这个函数只能调一次,对同一个数据库别名来说,只能调一次。所以要先判断要注册的数据库是否已经注册了。如果已注册,就不要再注册了,否则又会报错。所以写了一个class来处理这个问题。
具体的代码如下,
dbinit.go源代码,

package models import ( "database/sql" "github.com/astaxie/beego" "github.com/astaxie/beego/logs" "github.com/astaxie/beego/orm" _ "github.com/go-sql-driver/mysql" ) type DBInit struct { Db *sql.DB } func DBInitNew() *DBInit { db, _ := orm.GetDB() dbInit := DBInit{Db: db} return &dbInit } func (dbInit *DBInit) InitDatabase() { if dbInit.Db == nil { beego.LoadAppConfig("ini", "..\\conf\\app.conf") orm.RegisterDriver("mysql", orm.DRMySQL) dbType := beego.AppConfig.String("dbType") sqlConn := beego.AppConfig.String("sqlconn") maxIdle, _ := beego.AppConfig.Int("maxIdle") maxConn, _ := beego.AppConfig.Int("maxConn") logs.Info("Connect to [%v] database with conn: [%v] \n", dbType, sqlConn) orm.RegisterDataBase("default", dbType, sqlConn, maxIdle, maxConn) orm.Debug = true } } 

3.代码目录结构如下,


image.png

4.Swagger生成的API测试界面如下。

image.png

5.全量代码请参考GitHub。
https://github.com/zhuge20100104/bapi


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:FredricZhu

查看原文:Golang Beego Api连接Mysql简单示例(集成Swagger和Convey单测)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1234 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传