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

栏目: Go · 发布时间: 5年前

内容简介:1.工程创建步骤如下,如要集成swagger,请注意使用下面的语句启动beego。

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.代码目录结构如下,

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

image.png

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

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

image.png

5.全量代码请参考GitHub。

https://github.com/zhuge20100104/bapi

以上所述就是小编给大家介绍的《Golang Beego Api连接Mysql简单示例(集成Swagger和Convey单测)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS

CSS

David Sawyer McFarland / O'Reilly / 2006-08-24 / USD 34.99

Book Description Web site design has grown up. Unlike the old days, when designers cobbled together chunky HTML, bandwidth-hogging graphics, and a prayer to make their sites look good, Cascading St......一起来看看 《CSS》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

MD5 加密
MD5 加密

MD5 加密工具