Files
mayfly-go/devops/controllers/db.go

146 lines
4.1 KiB
Go
Raw Normal View History

2021-01-08 15:37:32 +08:00
package controllers
import (
"fmt"
"mayfly-go/base"
2021-03-24 17:18:39 +08:00
"mayfly-go/base/biz"
2021-01-08 15:37:32 +08:00
"mayfly-go/base/ctx"
"mayfly-go/base/model"
2021-03-24 17:18:39 +08:00
"mayfly-go/devops/controllers/form"
"mayfly-go/devops/controllers/vo"
"mayfly-go/devops/db"
"mayfly-go/devops/models"
2021-01-08 15:37:32 +08:00
"strconv"
)
type DbController struct {
base.Controller
}
// @router /api/dbs [get]
func (c *DbController) Dbs() {
2021-03-24 17:18:39 +08:00
c.ReturnData(ctx.NewNoLogReqCtx(true), func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
m := new([]models.Db)
querySetter := model.QuerySetter(new(models.Db))
return model.GetPage(querySetter, c.GetPageParam(), m, new([]vo.SelectDataDbVO))
})
}
// @router /api/db/:dbId/select [get]
func (c *DbController) SelectData() {
2021-03-24 17:18:39 +08:00
rc := ctx.NewReqCtx(true, "执行数据库查询语句")
c.ReturnData(rc, func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
selectSql := c.GetString("selectSql")
2021-03-24 17:18:39 +08:00
rc.ReqParam = selectSql
biz.NotEmpty(selectSql, "selectSql不能为空")
2021-01-08 15:37:32 +08:00
res, err := db.GetDbInstance(c.GetDbId()).SelectData(selectSql)
if err != nil {
2021-03-24 17:18:39 +08:00
panic(biz.NewBizErr(fmt.Sprintf("查询失败: %s", err.Error())))
2021-01-08 15:37:32 +08:00
}
return res
})
}
// @router /api/db/:dbId/exec-sql [post]
func (c *DbController) ExecSql() {
2021-03-24 17:18:39 +08:00
c.ReturnData(ctx.NewReqCtx(true, "sql执行"), func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
selectSql := c.GetString("sql")
2021-03-24 17:18:39 +08:00
biz.NotEmpty(selectSql, "sql不能为空")
2021-01-08 15:37:32 +08:00
num, err := db.GetDbInstance(c.GetDbId()).Exec(selectSql)
if err != nil {
2021-03-24 17:18:39 +08:00
panic(biz.NewBizErr(fmt.Sprintf("执行失败: %s", err.Error())))
2021-01-08 15:37:32 +08:00
}
return num
})
}
// @router /api/db/:dbId/t-metadata [get]
func (c *DbController) TableMA() {
2021-03-24 17:18:39 +08:00
c.ReturnData(ctx.NewNoLogReqCtx(true), func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
return db.GetDbInstance(c.GetDbId()).GetTableMetedatas()
})
}
// @router /api/db/:dbId/c-metadata [get]
func (c *DbController) ColumnMA() {
2021-03-24 17:18:39 +08:00
c.ReturnData(ctx.NewNoLogReqCtx(true), func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
tn := c.GetString("tableName")
2021-03-24 17:18:39 +08:00
biz.NotEmpty(tn, "tableName不能为空")
2021-01-08 15:37:32 +08:00
return db.GetDbInstance(c.GetDbId()).GetColumnMetadatas(tn)
})
}
// @router /api/db/:dbId/hint-tables [get]
// 数据表及字段前端提示接口
func (c *DbController) HintTables() {
2021-03-24 17:18:39 +08:00
c.ReturnData(ctx.NewNoLogReqCtx(true), func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
dbi := db.GetDbInstance(c.GetDbId())
tables := dbi.GetTableMetedatas()
res := make(map[string][]string)
for _, v := range tables {
tableName := v["tableName"]
columnMds := dbi.GetColumnMetadatas(tableName)
columnNames := make([]string, len(columnMds))
for i, v := range columnMds {
comment := v["columnComment"]
if comment != "" {
columnNames[i] = v["columnName"] + " [" + comment + "]"
} else {
columnNames[i] = v["columnName"]
}
}
res[tableName] = columnNames
}
return res
})
}
// @router /api/db/:dbId/sql [post]
func (c *DbController) SaveSql() {
2021-03-24 17:18:39 +08:00
rc := ctx.NewReqCtx(true, "保存sql内容")
c.Operation(rc, func(account *ctx.LoginAccount) {
2021-01-08 15:37:32 +08:00
dbSqlForm := &form.DbSqlSaveForm{}
c.UnmarshalBodyAndValid(dbSqlForm)
2021-03-24 17:18:39 +08:00
rc.ReqParam = dbSqlForm
2021-01-08 15:37:32 +08:00
dbId := c.GetDbId()
// 判断dbId是否存在
err := model.GetById(new(models.Db), dbId)
2021-03-24 17:18:39 +08:00
biz.BizErrIsNil(err, "该数据库信息不存在")
2021-01-08 15:37:32 +08:00
// 获取用于是否有该dbsql的保存记录有则更改否则新增
dbSql := &models.DbSql{Type: dbSqlForm.Type, DbId: dbId}
dbSql.CreatorId = account.Id
e := model.GetByCondition(dbSql)
dbSql.SetBaseInfo(account)
// 更新sql信息
dbSql.Sql = dbSqlForm.Sql
if e == nil {
model.UpdateById(dbSql)
} else {
model.Insert(dbSql)
}
})
}
// @router /api/db/:dbId/sql [get]
func (c *DbController) GetSql() {
2021-03-24 17:18:39 +08:00
c.ReturnData(ctx.NewNoLogReqCtx(true), func(account *ctx.LoginAccount) interface{} {
2021-01-08 15:37:32 +08:00
// 获取用于是否有该dbsql的保存记录有则更改否则新增
dbSql := &models.DbSql{Type: 1, DbId: c.GetDbId()}
dbSql.CreatorId = account.Id
e := model.GetByCondition(dbSql)
if e != nil {
return nil
}
return dbSql
})
}
func (c *DbController) GetDbId() uint64 {
dbId, _ := strconv.Atoi(c.Ctx.Input.Param(":dbId"))
2021-03-24 17:18:39 +08:00
biz.IsTrue(dbId > 0, "dbId错误")
2021-01-08 15:37:32 +08:00
return uint64(dbId)
}